三种方式取得类的字节码:
1. 类名.class
BranchInfoService.class
2. 对象名.getClass()
branchInfoService.getClass()
3. Class.forName(类全名),数据库驱动导入就是使用的这种方式:
Class.forName("com.garinzhang.BranchInfoService")
取得类的类装载器,使用字节码.getClassLoader()方法获得:
1. 最高类装载器:Bootstrap,由java虚拟机提供,内部使用C/C++实现,用于导入JDK核心类(加载jre/目录下的核心库),也用于导入另外两个类加载器:ExtClassLoader, AppClassLoader
// 打印为null,最高层的类加载器,取得为空 System.out.println(System.class.getClassLoader());
2. 类装载器ExtClassLoader会在启动时加载/jre/lib/ext/目录下的扩展包
// 打印出class sun.misc.Launcher$ExtClassLoader,根据路径可以找到此类 System.out.println(AcctRecordDTO.class.getClassLoader().getParent().getClass());
3. 应用编写的类-即项目中程序员编写的类(加载CLASSPATH路径下的包),由AppClassLoader导入:
// 打印出 sun.misc.Launcher$AppClassLoader@192d342,根据路径可以找到此类 System.out.println(AcctRecordDTO.class.getClassLoader());
ExtClassLoader和AppClassLoader不是继承关系,但是为什么可以使用class.getClassLoader.getParent()取到ExtClassLoader呢?这个待研究
继承关系:
java.lang.Object
--- java.lang.ClassLoader
--- java.security.SecureClassLoader
--- java.net.URLClassLoader
--- sun.misc.Launcher$ExtClassLoader
java.lang.Object
--- java.lang.ClassLoader
--- java.security.SecureClassLoader
--- java.net.URLClassLoader
--- sun.misc.Launcher$AppClassLoader
参考: