第一点
关于finally,联想到类似的final和finalized.
final:关键字1)修饰类–不可继承
2)修饰方法–不可覆盖重写
2)修饰变量–只可赋值一次,相当于常量
所以知道为什么不可以修饰构造方法了吧,联想:构造方法一般用在多态,父类引用指向子类对象,子类继承父类,你用final修饰后果就没意义了
finalized:这个是垃圾回收器,垃圾回收前,对象调用的方法,是Object类定义,很少用。因为垃圾回收时机难确定,所以方法调用难确定时机。
finally,是出现在
try{可能出现异常的代码}//把不是异常的放在里面容易出错
catch(异常类对象){异常处理代码
}finally{无论异常是否发生都会执行
一般释放资源用
}
1,有关finally和return,finally 里的代码会在return执行之前执行,这是因为java是先编译,把java编译成字节码文件,把finally编译到return之前。
2,什么时候finally不执行内,System.exit(0)这个是退出JVM,厉害吧
第二点
关于String(不可变的字符序列final char value[])易混淆点图解:
创建字符串对象的2种方式
String s1 = “abc”;(” “这样的都是指向方法区串池哟)
String s2 = new String(“bcd”);(这样的是指向堆内存中的地址,然后由堆指向串池)
编译器优化:
1,如果字符串字面值相加,编辑阶段就确定字符串具体内容,创建串池对象。
2,如果类型变量相加,编译阶段不确定,在执行阶段会创建对象。
第三点 StringBuffer 和 StringBuilder(底层System.arraycopy.会自动扩容,初始16,新长度16*2+2)
StringBuffer:老,JDK1.0,线程安全,效率低,方法有sychornized修饰
或者StringBuilder(新,JDK1.5 ,不是线程安全,效率高),大量字符串拼接时候可以使用。不可使用String,因为不可变,每次修改都会创建新对象
有关大量字符串拼接的时候做的优化
1,可以指定数组初始化容量(capacity),减少扩容次数,减少拷贝次数