Class:
包含与类有关的信息,每创建一个新类时,同时会创建一个Class对象(即同名的class文件)。在运行期,一旦我们想生成那个类的对象,JVM会先检查内存中是否已经载入Class对象,如果未载入,JVM找到同名class文件将其载入内存。
java程序不是完全载入的,而是在程序需要的时候才会载入相应的class文件
产生Class对象句柄的方法:
Class.forName(“className”);
类标记:ClassName.class 基本数据类型封装类用TYPE字段:eg:int.class == Integer.TYPE
object.getClass()
灵活利用Class对象可以得到对象的更多信息
package com.zd.java.rtti.grammer;
/**
* 在运行期间,可以得到对象的完整层次结构
* Class对象的灵活利用
* Created by ZD on 2017/10/15.
*/
interface HasBatteries{}
interface Waterproof{}
interface ShootsThings{}
class Toy{
Toy(){}
Toy(int i){}
}
class FancyToy extends Toy implements HasBatteries,Waterproof,ShootsThings{
FancyToy(){
super(1);
}
}
public class ToyTest {
public static void main(String[] args){
Class c = null;
try {
c = Class.forName("com.zd.java.rtti.grammer.FancyToy");
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
printInfo(c);
Class[] faces = c.getInterfaces();
for (int i = 0; i < faces.length; i++){
printInfo(faces[i]);
}
Class cy = c.getSuperclass();
Object o = null;
try {
o = cy.newInstance();//使用newInstance()必须有一个默认构造器
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
printInfo(o.getClass());
}
private static void printInfo(Class cc) {
System.out.println("class name: "+cc.getName()+" is interface? ["+cc.isInterface()+"]");
}
}
反射:运行期类型信息
java.lang.reflect包里添加了Field、Method、Constructor类,用来表示未知类里对应的成员,用构建器创建新对象;用get、set方法显示和修改Field相关字段;用invoke()调用与Method对象关联的方法。反射是在运行期间才打开对应的class文件,其他情况下是在编译期间就打开对应的class文件。
后续会对反射做更进一步地深入。