每天学一点:java虚拟机12

finalize()方法,垃圾收集器会在释放这个实例(所占用的内存空间)前执行这个方法一次;
finalize()方法抛出的任何异常都将被忽略;

判断动态装载的类型的class实例在正常的垃圾收集过程中是否是可触及的有两种方式:
1、如果程序保持对Class实例的明确引用,那就是可触及的;
2、如果在队中还存在一个可触及的对象,在方法区中它的类型数据指向一个Class实例,那这个Class实例就是可触及的;

动态连接和解析
驱动java连接模型的引擎是解析过程;
class文件把它所有的引用符号保存在一个地方--常量池;
每一个class文件有一个常量池,每一个被java虚拟机装载的类或者接口都有一份内部版本的常量池,称作运行是常量池;

解析过程就是根据符号引用查找到实体,再把符号引用替换成一个直接引用的过程。因为所有的符号引用都保存在常量池中,所以这个过程常被称为“常量池解析”;
程序运行时决定连接哪个类型:
1、通过传递类型的名字到java.lang.Class的forName()方法;
2、用户自定义的类装载器的loadClass()方法,也可以动态扩展java程序;
用户自定义的类装载器可以从java.lang.ClassLoader的任何子类创建;

每一个类装载器拥有一个独立的命名空间,这就为在不同的命名空间中装载的类型提供了一层安全防护。如果安全上需要包含一种定制方法把类型装载到保护域中,就需要使用类装载器而非forName()方法;

猜你喜欢

转载自baoxiaofei.iteye.com/blog/2273995