1 对象包装器与自动装箱
- 自动装箱规范要求 boolean、byte、char<=127;
- 介于 -128~127 之间的 short 和 int 被包装到固定对象中,可理解为如同字符串的常量池一样存储,效率高,节省空间。拆箱和装箱是编译器认可而不是虚拟机认可。
- 示例:
/**
* @version $Id: AutoBoxingTest.java, v 0.1 2017年6月4日 下午5:41:32
*/
public class AutoBoxingTest {
public static void main(String[] args) {
Integer integer1 = 127;
Integer integer2 = 127;
System.out.println(integer1 == integer2);//true
Integer integer3 = 128;
Integer integer4 = 128;
System.out.println(integer3 == integer4);//false
}
}
2 反射
能够分析类能力的程序称为反射。
-
Class
运行时系统始终为所有对象维护一个被称为运行时的类型标识。这个信息跟踪着每个对象所属的类,保存这些信息的类被称为 Class。 -
获取 Class 类型实例的三种方法
(1)调用对象的 getClass() 方法获取,因为 Object 类中使用 getClass() 返回一个 Class 类型的实例。
(2)使用 Class 的静态方法 forName(类名),获得类名对应的 Class 对象。
(3)第三种方法:Class cl = Double[].class
。
(4)示例程序:
/**
* @version $Id: ClassTest.java, v 0.1 2017年6月4日 下午6:20:05
*/
public class ClassTest {
public static void main(String[] args) {
try {
Person person = new Person();
Class class1 = person.getClass();
Class class2 = Class.forName("com.ly.tainci.exercise.Class.Person");
Class class3 = Person.class;
Person person1 = (Person) class1.newInstance();
Person person2 = (Person) class2.newInstance();
Person person3 = (Person) class3.newInstance();
System.out.println(person1);
System.out.println(person2);
System.out.println(person3);
} catch (ClassNotFoundException | InstantiationException | IllegalAccessException e) {
System.out.println("获取Class实例失败!");
}
}
}
- 通过反射可以分析类的能力
在java.lang.reflect
包中有三个类Field,Method,Constructor
分别描述类的域,方法和构造器。
3 继承的设计技巧
- 将公共操作和域放在超类。
- 不要使用受保护的域。
- 使用继承实现“is-a”关系。
- 除非所有继承的方法都有意义,否则不要使用继承。
- 在覆盖方法时,不要改变预期的行为。