面试官:听说你精通JVM,那我就考考你吧面试官:不用慌尽管说,错了也没关系😊。。。以贴近现实的【面试官面试】形式来分享技术,本期是《JVM系列》,感兴趣就关注我吧❤️
知道的。
主要是因为它很难解决对象之间相互循环引用的问题,所以目前都是采用可达性分析算法。
面试官思考中…
有4种,强引用、软引用、弱引用、虚引用。
面试官思考中…
会的,永久代里的废弃常量和无用的类会被回收。
例如类里面的常量没有其他任何引用,如果发生内存回收,有必要的话会进行清理。
面试官思考中…
主要是回收堆内存和方法区。
是这样的,程序计数器、虚拟机栈、本地方法栈的内存分配和回收具备确定性,都是随着线程销毁而销毁不需要进行回收。
但在堆内存、方法区在内存分配和回收都是动态的,我们只有在运行期间才能知道会创建哪些对象。
面试官思考中…
好的。
在垃圾回收期间系统的所有线程都会阻塞,但垃圾回收效率因此也效率高。
面试官思考中…
两者适合不同的业务场景。
面试官思考中…
是这样的,CMS采用了标记-清除算法。
分为了初始标记、并发标记、重新标记、并发清除四个阶段。
耗时最长的并发标记、并发清除可以和用户线程一起并发工作不需要停顿,其他阶段的耗时较短也就是说停顿也短。
面试官思考中…
面试官思考中…
主要是CMS的优点它都有,另外G1也避免了CMS的一些不足。
面试官思考中…
面试官思考中…
噢噢可以的。
复制算法一般是按1:1分配内存,但这也浪费了50%空间。
其实可以把内存分为一块较大的Eden空间和两块较小的Survivor空间,每次使用Eden和其中一块Survivor,而另一块Survivor用来保存回收时还存活的对象。
这样只浪费了其中一块Survivor空间的内存。
面试官抓抓脑袋,继续看你的简历......得想想考点你不懂的😰
好了,今天的分享就先到这,我们下期【JVM系列】继续。
创作不易,不妨点赞、收藏、关注支持一下,各位的支持就是我创作的最大动力❤️
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。