堆溢出和栈溢出

    jvm堆溢出和栈溢出

一、jvm堆溢出

1、介绍

在jvm运行java程序时,如果程序运行所需要的内存大于系统的堆最大内存(-Xmx),就会出现堆溢出问题。

2、案例

复制代码

// 介绍:执行该段代码需要大于10m内存空间
public class HeadOverflow {
    public static void main(String[] args) {
        List<Object> listObj = new ArrayList<Object>();
        for(int i=0; i<10; i++){
            Byte[] bytes = new Byte[1*1024*1024];
            listObj.add(bytes);
        }
        System.out.println("添加success");
    }
}
 
// 设置该程序的jvm参数信息
-Xms1m -Xmx10m -XX:+PrintGCDetails -XX:+HeapDumpOnOutOfMemoryError
初始堆内存和最大可以堆内存 Gc详细日志信息

复制代码

3、总结

在正式项目部署环境程序默认读取的是系统的内存,一般设置程序的堆初始内存(-Xms) == 堆最大可用内存(-Xmx)。

二、jvm栈溢出

1、介绍

a、线程请求的栈深度大于虚拟机允许的最大深度 StackOverflowError

b、虚拟机在扩展栈深度时,无法申请到足够的内存空间 OutOfMemoryError

理解:每次方法调用都会有一个栈帧压入虚拟机栈,操作系统给JVM分配的内存是有限的,JVM分配给“虚拟机栈”的内存是有限的。如果方法调用过多,导致虚拟机栈满了就会溢出。这里栈深度就是指栈帧的数量。https://www.cnblogs.com/lovlife/articles/12452502.html

2、案例

复制代码

// 循环递归调用,一直达到jvm的最大深度
public class StackOverflow {
     private static int count;
     
     public static void count(){
        try {
             count++;
             count(); 
        } catch (Throwable e) {
            System.out.println("最大深度:"+count);
            e.printStackTrace();
        }
     }
     public static void main(String[] args) {
         count();
    }
}

复制代码

 调整jvm 栈大小

C:\Users\rocky fang\Documents\mycode>java -Xss2m -cp "C:\Users\rocky fang\Documents\mycode" JavaStackTest
java.lang.StackOverflowError
stack height:23345

C:\Users\rocky fang\Documents\mycode>java -Xss5m -cp "C:\Users\rocky fang\Documents\mycode" JavaStackTest
java.lang.StackOverflowError
stack height:93213

C:\Users\rocky fang\Documents\mycode>java -Xss10m -cp "C:\Users\rocky fang\Documents\mycode" JavaStackTest
java.lang.StackOverflowError
stack height:423618

设置-Xss5m设置最大调用深度后调用

 总结:每个计算机都会有一个极限最大调用深度,避免递归在代码中无限循环。

          局部变量表内容越多,栈帧越大,栈深度越小。

三、内存溢出和内存泄露
1、区别
内存溢出:申请内存空间,超出最大堆内存空间。

内存泄露:其实包含内存溢出,堆内存空间被无用对象占用没有及时释放,导致占用内存,最终导致内存泄露。

      情况:静态static修饰对象。

      解决:减少常量的定义(具体看服务器内存情况) 

猜你喜欢

转载自blog.csdn.net/liyang_nash/article/details/108244188