您的位置:首页 > 编程语言 > Java开发

java编程思想读书笔记三(11-21)

2016-04-01 11:33 225 查看
十一:持有对象

》持有对象实例

●数组将数字与对象联系起来。它保存类型明确的对象,查询对象时,不需要对结果做类型转换。他可以是多维的。

可以保存基本的数据类型。但是,数组一旦生成,容量就不会在变。

●Collection保存单一的元素,而Map保存相关联的键值对。有了泛型,你就可以指定存放的对象类型,获取的时候,也不需要类型转换。各种Collection与Map都可以自动调整大小。容器不能持有基本类型。但是会自动包装。

●像数组一样,List也建立数字索引与对象的关联。因此,数组和List都是排好的容器。List可以自动扩展。

●如果要进行大量的随机访问,就用ArrayList,如果经常插入删除数据,用LinkedList。

●各种Queue以及栈的行为,都有LinkedList支持。

●Map是一种将对象与对象相关联的设计。HashMap用来快速访问。而TreeMap保持键始终处于排序状态。所以没有HashMap快。

●Set不接受重复元素。HashSet提供最快的查询速度。而TreeSet保持元素处于排序状态。

十二:通过异常处理错误

2、异常情形是指阻止当前方法或做用户继续执行的问题。异常情形和普通问题是不同的,所谓的普通问题是指:在当前环境下能得到足够多的信息,总能处理这个错误。而异

常情形是指:在当前环境下,无法或的必要的信息来解决问题。

3、抛出异常之后会发生的几件事情:

a、将会以new的方式在堆上创建一场对象的引用。

b、当前的执行路径会被终止,并获得弹出的异常的引用。

c、异常处理机制接管程序,并且从一个恰当的地方来继续执行程序。这个恰当的地方一般为catch或者finally

4、所有的标准异常类都有两个构造器,一个是默认构造器,另一个是接受字符串作为参数,以便能把相关信息放入异常

对象的构造器。

5、监控区域:是指可能产生异常的代码,并且后面跟着处理这些异常的代码。

6、异常处理理论中有两种模型:

a、终止模型,在这种模型中,将假设错误非常关键,一直与程序无法返回到一场发生的地方继续执行。一单一场被抛出

,就表明错误已经无法挽回,也不能回来继续执行。

b、恢复模型:是指异常处理程序的工作室修正错误,然后重新尝试解决问题。

以上两种模型相比较来说,常常使用终止模型。因为从复杂程度来说,要实现恢复模型,要编写大量处理代码。

7、对于一般的用户新建异常来说,最重要的就是类名的命名,也就是说,从Exception继承异常之后,几乎不用改什么。

8、异常的构造器一般有两个,一个是默认构造器,一个是接受参数的构造器。如果程序员想要自己实现一些构造器,那

么一般来说要重写getMessag()函数。
普通自己构建的异常如下:
class MyException extend Exception
{
public MyException(){}
public MyException(String msg)
{ super(msg); }
}

9、printStackTrace()方法如果是无参数形式,则默认输出到标准错误流。当然,可以向其中传递输出流的参数。

10、Exception类中有个一个getMessage()方法。通过覆盖此方法可以实现自定义形式的输出。

11、Exception类是所有异常的基类,所以,当catch异常时,要把catch(Exception e)写在最后,因为派生异常类可以匹配基异常类。

12、printStackTrace()可以直接打印异常栈轨迹。我们也可以通过调用getStackTrace()函数来获取所有的栈顺序,此函数以数组的形式返回栈轨迹。元素0是栈顶元素。

13、对于重抛异常来说,如果仅仅是简单讲当前一场对象重新抛出,那么printStackTrace()函数将显示原来的异常抛出位置,而不会显示重抛位置。要显示重抛位置,则需要用

原先的异常再构建一个新的异常之后抛出。关于如何构造的问题:

a、对于Error、Exception、RuntimeException三种异常,可直接在构造函数出将原有的异常传递即可。

b、对于除了以上三种异常之外,则需要调用initCause(异常 e)方法将异常传递。

14、如果RuntimeException没有被捕获而直达main(),那么在程序退出之前会默认调用printStackTrace()。

15、对于finally处理模块,无论怎样,这个模块总会被执行,可以用来最后的释放资源等操作。更重要的是,在一个方法中,可以从多个点返回,并且可以保证重要的清理工作仍然会进行,比如:

void haha(int num)
{
try
{
switch(num)
{
case 0:
return;//返回
break;
case 1:
return;//返回
break:
deflaut:
break;
}
}
finally
{
System.out.println("ok");
}
}
此时,无论从何处返回则finally中的输出部分肯定会执行。

16、在覆盖方法的时候,只能抛出在基类方法的异常说明里列出的那些异常。

17、派生类构造器不能捕获基类构造器抛出的异常。

18、对于派生类的异常和基类的异常来说,其异常种类只能变小不能变大。

>>异常使用指南

●在知道如何处理的情况下才捕获异常。

●解决问题并且调用产生异常的方法。

●进行少许修补。然后绕过异常发生的地方继续执行。

●用别的数据进行计算。以代替方法预计会返回的值。

●终止程序

●进行简化

●安全

●把当前运行环境下能做的事情尽量做完,然后把异常抛到高层。

十三:字符串

●String对象是不可变的。修改String值的方法,实际上创建了一个全新的String对象。以包含修改后的字符串。而最初的String对象则丝毫未动。

●用于String的“+”与“+=”是java中仅有的两个重载过操作符,而java并不允许程序运重载任何操作符。

●当你为一个类编写toString()方法时,如果字符串操作比较简单,那就可以信赖编译器,它会为你合理的构造最终的字符串结果。但是,如果你要在toString()方法中使用循环或者比较复杂的字符串连接操作,那么最好自己创建一个StringBuilder对象,用它来构造最终的结果。

●如果你想要打印出某个对象的地址,用Object.toString()而不是直接打印this。

●System.out.format的用法和C中的printf()用法相同,当然,Java也提供了System.out.printf()此种写法。

●关于正则表达式的部分可以用到的时候再涉猎,因为很多东西我们平时是不会接触的。

》十四:类型信息

●运行时信息可以使得你可以在运行时发现和使用类型信息。

●每个类都有一个Class对象。可以使用.class来创建Class对象的引用。

●所有的类都是在对第一次使用时,动态加载到JVM中的。当程序创建第一个对类的静态成员的引用时,就会加载这个类。这个证明构造器也是类的静态方法。因此,使用New操作符创建类的新对象也会被当做对类的静态成员的引用。

●Class对象仅在需要的时候才被加载,Static初始化是在类加载时进行的。

●仅使用.class语法来获取的引用不会引发初始化。但是为了产生Class引用,Class.forName()立即就会进行初始化。







内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: