深入了解JVM避免内存泄漏提高代码价值
大家好我今天给大家介绍的是JVM减少内存泄漏提高代码价值
如上图大家应该都知道JVM的三种模型方法区,堆,栈。
方法区:简单理解方法区就是存放类的基本信息比如一些静态常量,全局变量等。
堆:堆存放的是就是一些类的实体等
栈:线程执行执行代码的地方,每个方法调用一个栈帧(局部变量跟this引用)
大家也了解过JVM里面的GC机制吧(垃圾回收机制)
垃圾回收机制也是在方法区,堆,栈中进行回收
GC发现垃圾的机制:
1.引用计数法:通过计算代码是否被引用,则断定该过程不是垃圾,缺点是无法检测出相互引用的垃圾对象。
2.根搜索算法:如果代码是引用的是垃圾对象则判定为垃圾代码进行回收,如下图对象实例3跟对象实例5就是垃圾对象相互引用。
接下来重点回收垃圾的方式
1.标记-整理算法
标记过程仍然与“标记-清除”算法一样,但后续步骤不是直接对可回收对象进行清理,而是让所有存活的对象都向一端移动,然后直接清理掉端边界以外的内存,这种算法克服了复制算法的低效问题,同时克服了标记清除算法的内存碎片化的问题;
2.分代收集算法
把Java堆分为新生代和老年代,这样就可以根据各个年代的特点采用最适当的收集算法。在新生代中,每次垃圾收集时都发现有大批对象死去,只有少量存活,那就选用复制算法,只需要付出少量存活对象的复制成本就可以完成收集。而老年代中因为对象存活率高、没有额外空间对它进行分配担保,就必须使用“标记-清理”或“标记-整理”算法来进行回收。
内存泄漏
如下图的示例代码可以看出stu有俩个引用,所以在销毁掉一个引用侯他还不是垃圾代码所以不会被销毁掉,只有把两条引用都销毁才能被垃圾回收销毁。
编写高效代码的技巧
1.尽量不要在循环中使用try…catch,new对象;
2.把频繁短命对象都缓存起来
3.尽可能使用栈内变量
4.用线程池,连接池,不要自己创建等等。
接下来是搞笑的怎么把JVM弄炸
很简单在JVM配置中修改个个区域的内存,范围在JVM承受不了的范围这样就会照成JVM一直在想法设法的去清理回收垃圾,然后在JVM受不了啦就炸啦哈哈哈哈哈。
1.调整堆内存大小:-Xms256M -Xmx512M
2.调整栈内存大小:-Xss2048k
3.调整方法区大小:-XX:MetaspaceSize=64M
-XX:MaxMetaspaceSize=128M
以上就是我的分享希望对你有帮助,谢谢阅读开心xixi 。