如何理解垃圾回收(gc)

如题所述

作者:朱克锋1:垃圾回收机制由JVM完全负责,编写者在抛弃对象时不必关系空间回收问题2:JVM的垃圾回收机制对堆空间做实时监测,当发现某对象的引用计数为0时,就将该对象列入待回收系类中并不是马上予以销毁3:某个对象被认定为没有必要存在了,那么它所占用的内存就可以被释放,被回收的内存可以用于后续的再分配,并不是对象被抛弃后就立即被回收,垃圾回收器通常只在有对象要回收且系统需要回收时才运行,因此用户无法知道垃圾回收发生的精确时间4:system,gc()也仅仅是一个回收请求,JVM接受到这个消息后并不是立即做垃圾回收,而只是对几个垃圾回收算法做加权使垃圾回收操作容易发生或提前发生5:当对象即将被销毁时,有时需要做一些善后工作,可以把这些操作写在finalize()方法里(终止器)注:到程序接受时,并非所有收尾模块都会得到调用当指向某个对象的最后一个引用被删除,那么该对象就可以被删除:在对象的无用时可以回收Java的垃圾回收并不能保证内存的耗尽,其只是一个低优先级的后台线程且跟踪可达或者不可达的对象A:当JVM的拦截器调用一个合适对象的finalize()方法时,它会忽略任何由finalize()方法抛出的异常,其它情况下finalize()方法中的异常处理同普遍方法的出来是一样的B:Object对象有一个finalize()方法,由于所有的参数都是从Object类继承而来,因此所有对象有一个finalize()方法C:类可以覆盖finalize()方法,而且和普通的方法覆盖一样,不能降低finalize()方法的访问权限,调用finalize()方法本身不会破坏对象
温馨提示:答案为网友推荐,仅供参考