目录
10、内存中一个类的字节码对象(Class)对象可以有多个吗?
1、类加载子系统简单图解
- 查找类---从指定路径内找到类名+包名对应的文件;
- 读取类---通过字节输入流读取类;
- 校验类---对读取到的类进行校验,默认初始化;
- 创建字节码对象。
2、类加载子系统中有哪些类加载器
2.1 BootStrapCladdLoader(基础类库加载器)
负责加载基础类库中的类,如lib/Object、String....;
2.2 ExtClassLoader(扩张类加载器)
负责加载扩张类库中的类 lib/ext/ ...
2.3 AppClassLoader(应用程序类加载器)
负责加载ClassPath路径下我们自定义的类...
2.4 自定义ClassLoader(自定义类加载器)
自己自定义加载路径和加载方式
3、什么是双亲委派模型?
依次向上询问是否加载过此类,假如加载过则无需再加载;
若未加载过,从顶层(BootStrap)开始,依次尝试加载此类;
若可以加载,则加载;
4、为什么使用双亲委派模型
这种机制可以保证一个类不被多次重复加载。
例如java.lang.Object,在基础类库中一被加载。
5、双亲委派模型有什么弊端
假如不同项目部署到同一个Web服务器中,不同项目中有同类名、同包名、但不同内容的类
会导致其中一个类不会被加载;
可以通过自定义类加载器来解决。
6、什么情况下会触发类加载
- 直接通过类加载器的classLoad去加载;
- 通过Class.forName(包名.类名)去加载;
- 直接访问类的属性、方法、构造类的对象;
7、类加载一定会执行静态代码吗?
不一定,静态代码块是否执行取决于类加载时是否执行了类的初始化。
8、如何理解主动加载和被动加载
可以,当系统提供的类加载器不满足我们需求时,我们可以通过直接或间接的继承ClassLoader的方式,来定义自己的类加载器。 例如: class SimpleClassLoader extends ClassLoader{ ... }
9、什么场景下需要自定义类加载器
- 打破双亲委派加载模型(自定定义加载器)
- 保证类的安全时(类编译时加密,加载类时解密)
- 指定加载源头(从数据库中读取类)
10、内存中一个类的字节码对象(Class)对象可以有多个吗?
可以,即使是同一个类,但是它的类加载器不同,生成的字节码对象也可以不同。