第二周预习:异常类,常用类,容器

异常类

异常

异常:在程序的运行过程中,发生了不正常的现象,阻止了程序的运行,我们称之为发生异常。
Java使用throw关键字抛出一个Exception子类的实例表示异常发生。

try-catch语句

语句格式

try{
包含可能发生异常的语句
}
catch(ExcptionSubClass1 e) {
  ...
}
catch(ExcptionSubClass2 e) {
  ...
}
  • try中没有异常,catch中代码不执行
  • try中有异常,catch进行捕获
    如果catch中的异常类型和出现的异常类型匹配的话,执行catch中的代码,进行捕获。
    如果catch中的异常类型和出现的异常类型匹配的话,不执行catch中的代码,不进行捕获。程序相当于遇到异常,中断。
  • try中如果出现异常,然后用catch捕获成功的话,那么try中的后续代码是不会执行的。
  • 如果catch捕获异常成功,那么try-catch后面的代码该执行还是执行没有影响。

catch处理异常方式

  • 什么都不做
  • 输出自定义异常信息
  • 打印异常信息
    调用toString方法,显示异常的类名。System.out.println (e.toString ());
    显示异常描述信息对应的字符串。System.out.println (e.getMessage ());
    显示异常的堆栈信息:将异常信息捕获以后,在控制台将异常的效果展示出来。
    e.printStackTrace();
  • 抛出异常. throw e

自定义异常类

在编写程序是可以扩展Exception类定义自己的异常类,然后根据程序的需要来规定哪些方法产生这样的异常。一个方法在声明时可以使用throws关键字声明要产生的若干个异常,并在该方法的方法体中具体给出产生异常的操作,即用相应的异常类创建对象,并使用throw关键字抛出该异常对象,导致该方法结束执行。
自定义的异常可继承:运行时异常,也可以继承检查异常。
如果继承的是运行是异常,那么在使用的时候无需额外处理。
如果继承的是检查异常,那么使用的时候需要try-catch捕获或者throws。

常用类

String类

构造String对象

常量对象

String str = "abc"

String对象

String s = new String("We are students");
String t = new String("We are students");
String类的构造方法

String (char a[])用一个字符数组a创建一个String 对象

char a[] = {'j','a','v','a'};
String s = new String(a); 

相当于

String s = new String("Java");

String(char a[],int startIndex.int count) 提取字符数组a中的一部分字符创建一个String对象,参数startIndex和count分别指定在a中提取字符的起始位置和从该位置开始截取的字符个数。

char a[] = {'零''壹''贰''叁''肆''伍''陆''染''捌''项');
String s = new String(a,2,4);

相当于

String s = new Srting("贰叁肆伍")

引用String常量

String s1,s2;
s1 = "你好";
s2 = "你好";
字符串的并置
String you = "你";
String hi = "好";
String testOne;
testOne=you+hi;
Sytem.out.println (hello == testOwo); //输出结果是false
String hello = "你好";
String testTwo = "你"+"好";
Sytem.out.println (hello == testTwo); //输出结果是true
Sytem.out.println ("你好" == testTwo); //输出结果是true
Sytem.out.println ("你好" == testTwo); //输出结果是true
String testThree = you+hi;
Sytem.out.println (testThree == testOwo); //输出结果是false

#####String类的常用方法

public int length 获取一个String对象的字符序列的长度。
2. public boolean equals(String s) 比较当前String对象的字符序列是否与参数s指定的String对象的字符序列相同。
3. public boolean startsWith(String s) 判断当前String对象的字符序列前缀是否是参数指定的String对象s的字符序列。
4. public boolean endsWith(String s) 判断当前String对象的字符序列后缀是否是参数指定的String对象s的字符序列。
5. public int compareTo(String s) 按字典序与参数指定的String对象s的字符序列比较大小。相同返回值为0,大于s的字符序列,返回正值,小于s的字符序列,返回负值。 public int compareToIgnoreCase(String s) 该方法忽略大小写。
6. public boolean contains(String s) 判断当前String对象的字符序列是否包含参数s的字符序列。
7. public int indexOf(String s,int fromIndex) 从下标fromIndex处开始开始查找str在字符串中第一次出现的位置。
8. public int lastIndexOf(String s,int fromIndex) 从下标fromIndex处开始开始查找str在字符串中最后一次出现的位置。
9. public String substring(int startpoint) 获得一个新的String对象,新的String对象的字符序列是复制当对象的字符序列中的startpoint 位置至最后位置上的字符所得到的字符序列。String对象调用substring(int start, int end)方法获得一个新的 Sting对象,新的Sring 对象的字符序列是复制当前Srinrg对象的字符序列中的un位置至end-1位置上的字物所得到的字符序列。

字符串与基本数据的相互转化

Integer类调用其类方法public static int parseInt(String s)可将有“数字”字符组成的字符序列,转化为int型数据。

int x
String s = "876";
x = Integea.parseInt (s);

将数值转化为String对象

String str = String.valueOf (12312.9876);

StringTokenizer类

当分析一个String对象的字符序列并将字符序列分解成可被独立使用的单词时,可以使用java.util包中的StringTokenizer类,该类有两个常用的构造方法。

  • StringTokenizer(String s): 为String对象s构造一个分析器。使用默认的分隔标记,即空格符、换行符、回车符、Tab 符、进纸符做分隔标记。
  • Sringeizer(String s, Sring delim);为Sring对象s构造一个分析器。 参数delim的字符序列中的字符的任意排列被作为分隔标记。
StringTokenizer fenxi = new StringTokenizer("you are welcome");
StringTokenizer fenxi = new StringTokenizer("you#*are*##welcome", "*#");

Scanner类

Scanner对象

Scanner对象可以解析字符序列中的单词

String NBA = "I Love This Game";

为了解析出NBA的字符序列中的单词,可以构造一个Scanner对象

Scanner scanner = new Scanner (NBA);

Scanner对象可以调用方法

useDelimiter (正则表达式);

StringBuffer类

StringBuffer对象

StringBuffer类的对象的实体的内存空间可以自动地改变大小,便于存放一个可变的字符序列。

StringBuffer s = new StringBuffer("我喜欢");

对象s可调用append方法追加一个字符序列

s.append ("玩篮球");

StringBuffer类有三个构造方法:

  • StringBuffer();
  • StringBuffer(int size);
  • StringBuffer(String s);
StringBuffer类的常用方法
  • StringBuffer append(String s)将String对象s的字符序列追加到当前StringBuffer对象的字符序列中。
  • public char charAt(int n) 得到StringBuffer对象的字符序列位置n上的字符。
  • public char setCharAt(int n) 将当前StringBuffer对象的字符序列位置n处的字符用参数ch指定的字符替换。
  • StringBuffer insert(int index, String str) 使用insert方法将参数str指定的字符序列插入到参数index指定的位置。
  • public StringBuffer reverse() 使用reverse方法将该对象实体中的字符序列翻转。
  • StringBuffer delete(int startIndex, int endIndex) 从当前StringBuffer对象的字符序列中删除一个子字符序列。删除的子字符序列从startIndex位置到endIndex-1位置。
  • StringBuffer replace(int startIndex, int endIndex, String str) 将当前StringBuffer对象的字符序列的一个子字符序列用参数str指定的字符序列替换。被替换的子字符序列从startIndex位置到endIndex-1位置。

Date类与Calendar类

Date类

使用无参构造方法

Date nowTime = new Date();

使用带参数的构造方法

Date date1 = new Date(1000),
date2 = new Date(-1000);
Calendar类

日期的格式化

format方法
format (格式化模式,日期列表)

格式化模式:是一个用双引号括起来的字符序列,该字符序列中的字符由时间格式符和普通字符所构成。
日期列表:可以使用逗号分隔的Calendar对象或Date对象。

Date nowTime = new Date();
String s1 = String.format ("%tY年%tm月%td日",nowTime,nowTime,nowTime);

格式化同一日期:用几个格式符号格式“日期列表”中的同一个日期,可以在“格式化模式”中使用“<” 。

String str1 = String.format ("%tY年%<tm月%<td日",nowTime);
不同区域的星期格式
format (Locale locale,格式化模式,日期列表);
String s = String.format (Locale.US,"%ta (%<tF)",new Date());

Math类、BigInteger类和Random类

Math类
  • public static long abs(double a):返回 a的绝对值 。
  • public static double max(double a,double b):返回a、b的最大值。
  • public static double min(double a,double b):返回a、b的最小值。
  • public static double random():产生一个 0~1之间的随机数(不包括0和1).public static double pow(double a,double b):返回a的b次幂。
  • public static double sqrt(double a): 返回a的平方根。
  • public static double log(double a):返回a的对数。
  • public static double sin(doublea):返回a的正弦值。
  • public static double asin(double a):返回a的反正弦值。
  • public static double ceil(doublea):返回大于a的最小整数,并将该整数转化为double型数据。例如,Math.ceil(15.2)的值是16.0。
  • public static double floor(double a): 返回小于a的最大整数,并将该整数转化为double型数据。例如,Math.floor( 15.2)的值是15.0,Math.floor(-15.2)的值 是-16.0。
  • public static long round(double a):返回值是(long)Math.floor(a+0.5)),即所谓a的“四舍五入”后的值。一个比较通俗好记的办法是:如果a是非负数,round 方法返四a的四舍五入后的整数(小数大于等于0.5入,小于0.5舍):如果a是负数,round方法返回a的绝对值的四舍五入后的整数取负,但注意,小数大于0.5入,小于等于0.5舍,例如,Math.round(-15.501)的值是-16。Math.round(-15)。
BigInteger类
  • public BigInteger add(BigInteger val):返回当前对象与val的和。
  • public BigInteger subtract(BigInteger val): 返回当前对象与val的差。
  • public BigInteger multiply(BigInteger val): 返回当前对象与val的积。
  • public BigInteger divide(BigInteger val):返回当前对象与val的商。
  • public Biglnteger remainder(BigInteger val):返回当前对象与val的余。
  • public int compareTo(BigInteger val):返回当前对象与val的比较结果,返回值是1,-1或0,分别表示当前对象大于、小于或等于val。
  • public Biglnteger abs0:返回当前整数对象的绝对值。
  • public Biglnteger pow(int a);:返回当前对象的a次幂。
  • public String toString():返回当前对象十进制的字符串表示。
  • public String toString(int p):返回当前对象p进制的字符串表示。
Random类

返回一个随机整数

 Random random = new Random();
 random.nextInt ();

返回一个0~n之间的随机数

 Random random = new Random();
 random.nextInt (100);//返回0~99之间的某个整数(包括0,不包括100)

返回一个随机boolean值

random.nextBoolean ();

Class类与Console类

Class类

使用Class的类方法得到一个和某类相关的Class对象:

public static Class forName (String className) throw ClassNotFoundException

对Class方法的调用

public Object newInstance () throws InstantiationException,
IllegalAccessException
Console类

如果希望在键盘输入一行文本,但不想让该文本回显,即不在命令行显示。

Console cons = System.console ();   

###Patter类与Matcher类

Patter类

建立Patter类对象

Pattern patter = Patter.compile (regex);//正则表达式regex做参数
String regex = "good";
pattern = Pattern.compile (regex);
Matcher

得到Matcher对象

Matcher matcher = pattern.matcher (input);

容器

概述

容器可以管理对象的生命周期、对象与对象之间的依赖关系,您可以使用一个配置文件(通常是XML),在上面定义好对象的名称、如何产生(Prototype 方式或Singleton 方式)、哪个对象产生之后必须设定成为某个对象的属性等,在启动容器之后,所有的对象都可以直接取用,不用编写任何一行程序代码来产生对象,或是建立对象与对象之间的依赖关系。

容器类

Java 容器分为 Collection 和 Map 两大类,其下又有很多子类,如下所示:

  • Collection
    List
    ArrayList
    LinkedList
    Vector
    Stack

  • Set
    HashSet
    LinkedHashSet
    TreeSet

  • Map
    HashMap
    LinkedHashMap

  • TreeMap
    ConcurrentHashMap
    Hashtable

  • List的实现类(ArrayList,Vector,LinkedList)
    ArrayList和Vector内部是线性动态数组结构,所以查询效率上会高很多,Vector是线程安全的,相比ArrayList线程是不安全的,所以性能会稍慢一些。
    LinkedList:是双向链表的数据结构存储数据,在做查询时会按照序号索引数据进行前向和后向遍历,查询效率偏低,但插入数据时只需要记录本项的前后项即可,所以插入速度较快。

  • Set的实现类有HashSet和TreeSet
    HashSet:它的内部是哈希表(实际上是一个HashMap实例)支持的。但他不保证set元素的迭代顺序。
    TreeSet:TreeSet使用元素的自然顺序对元素进行排序,或者根据创建set时提供的Comparator进行排序。

  • Map接口有三个实现类:Hashtable,HashMap,TreeMap,LinkedHashMap
    Hashtable:内部存储的键值对是无序的,是按照哈希算法进行排序,与HashMap最大的区别就是线程安全。键或者值不能为null,为null就会抛出空指针异常。
    TreeMap:基于红黑树(red-black tree)数据结构实现,按key排序,默认的排序方式升序。
    LinkedHashMap:有序的Map集合实现类,相当于一个栈,先put进去的最后出来,先进后出。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值