标签:次数 serial 详细 内存 内存泄露 申请 print 示例 日志
常见参数配置总结:在实际工作中,我们可以直接将初始的堆大小与最大堆大小相等,这样的好处是可以减少程序运行时垃圾回收次数,从而提高效率
使用示例: -Xmx20m -Xms5m
当前堆最大内存 20M,堆初始化内存 5M
使用示例:-Xms20m -Xmx20m -Xmn1m -XX:SurvivorRatio=2 -XX:+PrintGCDetails -XX:+UseSerialGC
当前堆最大内存 20M,初始化堆内存 20M,新生代最大可用内存 1M,Eden 区域和 form、to 区域的比例是 2:1:1,打印 GC 日志,使用串行回收
使用实例:-Xms20m -Xmx20m -XX:SurvivorRatio=2 -XX:NewRatio=2 -XX:+PrintGCDetails -XX:+UseSerialGC
当前堆最大内存 20M,初始化堆内存 20M,Eden 区域和 form、to 区域的比例是 2:1:1,新生代和老年代比例是 1:2,打印 GC 日志,使用串行回收
错误原因:java.lang.OutOfMemoryError: Java heap space 堆内存溢出
设置合适的堆大小:-Xms1m -Xmx100m -XX:+PrintGCDetails -XX:+HeapDumpOnOutOfMemoryError
最后的参数表示堆内存溢出出打印快照
错误原因:java.lang.StackOverflowError 栈内存溢出
虚拟机栈溢出发生在递归调用,循环不会产生虚拟机栈溢出,除非循环里面嵌套递归
设置更大的深度,默认深度大概在 10000 左右
-Xss5m 设置最大调用深度
内存溢出:申请空间超出系统能够提供的空间大小
内存泄露:内存泄露是指程序中间动态分配了内存,但在程序结束时没有释放这部分内存,从而造成那部分内存不可用的情况,最终导致内存溢出
标签:次数 serial 详细 内存 内存泄露 申请 print 示例 日志
原文地址:https://blog.51cto.com/13559120/2383469