网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
对象的自我拯救(生存还是死亡)
在根搜索算法中,通过可达性分析,那些不可达的对象并不是立即被销毁,他们还有被拯救的机会。如果要真正宣告一个对象死亡,需要经历两次标记过程,首先是第一次标记,并判断对象是否覆写了 finalize() 方法。
- 当对象没有重写finalize()方法或者finalze()方法已经被虚拟机调用过,虚拟机讲这两种情况都认为此对象没有必要执行finalize()方法,即自救失败,直接进行第二次标记并被回收。
- 当对象重写了finalize()方法时,如果对象在finalize()方法中重新与引用链建立了关联关系,那么将会逃离本次回收,自救成功。
这个对象会被放置在一个叫做F-Queue的队列之中,并在稍后由一条虚拟机自动创建的、低优先级的Finalizer线程去执行finalize()方法,finalize()方法是对象逃脱死亡命运的最后一次机会(因为一个对象的finalize()方法最多只会被系统自动调用一次)。
稍后垃圾收集器将会对F-Queue中的对象进行第二次小规模的标记,如果对象要在finalize()中成功拯救自己,只要与引用链上的任何一个对象建立关联即可,例如把当前对象的引用this赋值给某对象的类变量/成员变量。第二次标记时这个对象将会被移除“缓刑”阶段(自救成功)。而如果对象这时还没有关联到任何链上的引用,自救失败,那它就会被回收掉。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
ttps://bbs.youkuaiyun.com/topics/618658159)**