java 类字面常量, 泛化的 Class 引用
类名. class 就是字面常量, 代表的就是该类的 Class 对象引用. 常量需要赋值给变量
简单, 安全. 编译期接受检查, 不需要像 forName 一样置于 try/catch 块中.
加载后不会进行初始化, 初始化被延迟到静态方法静态域首次使用时.
类字面常量可用于类 接口 数组 基本数据类型
基本数据类型也有类字面常量如 int.class, 对应的包装器的 Integer.TYPE.System.out.println(int.class);//int
System.out.println(Integer.TYPE);//int
System.out.println(Integer.class);//class java.lang.Integer
Integer 继承自 Number 但 Integer Class 对象不是 Number Class 对象的子对象, 也就是说 Class cn = int.class; 是错误的.
二. 泛化的 Class 引用
1. 普通的类引用可以重新指向任何其它的 Class 对象, 使用泛型类引用只能赋值为指向其声明的类型, 除外使用通配符?ClassintClass=int.class;
ClassgenericIntClass=int.class;
Class>i=int.class;
i=double.class;
genericIntClass=Integer.class;// Same thing
intClass=double.class;
2.Class> 优于 Class 因为 Class 在编译期不会产生警告, 而 Class> 当指向一个非具体的类引用时会产生警告
3.a.newInstance() 如果 Class 引用 a 不是泛型引用, 在编译期就不知道它会返回什么类型那么只能返回 Object.Classa=A.class;
Objectt=a.newInstance();
//A t = (A) a.newInstance();// 无法确定类型需要强制转换
System.out.println(t.getClass().getName());//thinking14class.A
4.a.newInstance() a 是泛型引用并且能确定类型则会返回确切的类型.Classa=A.class;
Class<?extendsC>c=C.class;// 上界
Class<?superA>d=A.class;
A ta=a.newInstance();// 可以确定
A tc=c.newInstance();// 上界至少它是一个 C 可以确定
5. a.newInstance() a 是泛型引用但不能确定类型则只能返回 Object.
Classa=A.class;
Class<?extendsC>c=C.class;// 上界
Class<?superA>d=A.class;// 下界
//A ta = a.newInstance(); // 通配符无法确定
A tc=c.newInstance();// 上界至少它是一个 C 可以确定
//A td = d.newInstance();// 下界无法确定
6. 利用 Class 类的 cast() 方法来转换类型classBuilding{
}
classHouseextendsBuilding{
}
publicclassClassCasts{
publicstaticvoidmain(String[]args){
Buildingb=newHouse();
ClasshouseType=House.class;
Househ=houseType.cast(b);
h=(House)b;// ... or just do this.
}
}///:~
fd
来源: http://www.bubuko.com/infodetail-2946177.html