堆内存、栈内存以及溢出的排查

作者: 彳亍口巴 | 来源:发表于2020-07-28 09:54 被阅读0次
栈内存和堆内存的区别

在Java中,栈(stack)是由编译器自动分配和释放的一块内存区域,主要用于存放一些基本类型(如int、float等)的变量、指令代码、常量及对象句柄(也就是对象的引用地址)。
  栈内存的操作方式类似于数据结构中的栈(仅在表尾进行插入或删除操作的线性表)。栈的优势在于,它的存取速度比较快,仅此于寄存器,栈中的数据还可以共享。其缺点表现在,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性
  堆(heap)是一个程序运行动态分配的内存区域,在Java中,构建对象时所需要的内存从堆中分配。这些对象通过new指令“显式”建立,这种分配方式类似于数据结构中的链表。堆内存在使用完毕后,是由垃圾回收(Garbage Collection,GC)器“隐式”回收的
  堆的优势是在于动态地分配内存大小,可以“按需分配”,其生存期也不必事先告诉编译器,在使用完毕后,Java的垃圾收集器会自动收走这些不再使用的内存块。其缺点为,由于要在运动时才动态分配内存,相比于栈内存,它的存取速度较慢。


内存溢出的排查流程

jvisualvm:可以用来查看分析内存转储文件,也可以用其做Java虚拟机当前状况查看

内存溢出时的虚拟机状况
从上图可以知道,是在com.zas.jvm.om.DataObject这个类的对象出了问题。

在Linux环境下,可以借助jdk自带的jmap来转储堆内存文件来分析。
定位方法:用JDK自带的命令jmap -histo pid去查看堆内存的使用情况

会看到实例被调用的次数,从大到小排序,越排前面说明占内存空间越大

发现排名第一的就是自己应用程序里所调用的方法,此时只需要在代码里找到该方法,发现该方法使用之后没有及时被释放导致的内存溢出


引用(本文章只供本人学习以及学习的记录,如有侵权,请联系我删除)

栈内存和堆内存的区别
堆内存溢出定位方法
Java内存溢出问题的定位过程

相关文章

网友评论

    本文标题:堆内存、栈内存以及溢出的排查

    本文链接:https://www.haomeiwen.com/subject/ldgxrktx.html