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

十一:持有对象

 》持有对象实例

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

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

   ●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()立即就会进行初始化。

   ●

   ●

   ●

   ●

posted @ 2016-04-01 11:33  戎码一生  阅读(342)  评论(0编辑  收藏  举报