java的GC只负责内存相关的清理,全部其它资源的清理必须由程序员手工完成。要否则会引发资源泄露,有可能致使程序崩溃。java
调用GC并不保证GC实际执行。程序员
finalize抛出的未捕获异常只会致使该对象的finalize执行退出。编程
用户能够本身调用对象的finalize方法,可是这种调用是正常的方法调用,和对象的销毁过程无关。函数
JVM保证在一个对象所占用的内存被回收以前,若是它实现了finalize方法,则该方法必定会被调用。Object的默认finalize什么都不作,为了效率,GC能够认为一个什么都不作的finalize不存在。对象
finalize()是Object的protected方法,子类能够覆盖该方法以实现资源清理工做,GC在回收对象以前调用该方法。内存
finalize()与C++中的析构函数不是对应的。C++中的析构函数调用的时机是肯定的(对象离开做用域或delete掉),但Java中的finalize的调用具备不肯定性资源
不建议用finalize方法完成“非内存资源”的清理工做,但建议用于:作用域
① 清理本地对象(经过JNI建立的对象); ② 做为确保某些非内存资源(如Socket、文件等)释放的一个补充: 在finalize方法中显式调用其余资源释放方法。其缘由可见下文[finalize的问题]效率
对象必须覆写了finalize()方法程序
finalize()只会在对象内存回收前被调用一次
finalize()的调用具备不肯定行,只保证方法会调用,但不保证方法里的任务会被执行完(好比一个对象手脚不够利索,磨磨叽叽,还在自救的过程当中,被杀死回收了)。
finalize()方法并无什么鸟用,(而且在新版JAVA中已被弃用)。
至于为何会存在一个鸡肋的方法:书中说“它不是C/C++中的析构函数,而是Java刚诞生时为了使C/C++程序员更容易接受它所作出的一个妥协”《JAVA编程思想》。