美文网首页
jvm堆栈内存介绍

jvm堆栈内存介绍

作者: 吴世浩 | 来源:发表于2017-05-15 00:29 被阅读32次

一、好言

礼貌是因为陌生 胡闹是因为熟悉。

二、背景

看书,摘抄的重点,总结,不过这个大部分都是摘抄的重点,提取出来记录。《Java问题定位技术》。

三、内容

3.1 jvm内存模型
java进程内存,指整个Java进程占用的内存。即是java堆内存、Perm内存、本地内存与加载的可执行文件和库所占用内存的总和。

3.2 三个部分介绍
(1)java堆内存
Java堆内存,这是JVM 用来分配java对象内存。即通过-Xmx -Xms设置的用来分配给java对象的内存。当使用new的时候就是使用这块内存进行分配。
(2)Perm内存:其全称是Permanent Generation space ,是指内存的永久保存区域,可以通过-XX :PermSize 设置的内存,这块内存是虚拟机用来加载class字节码文件的内存。这块内存在系统运行期一般比较固定。因为类文件是有限的。这里所说的一般,还有一些不一般的情况,目前在有些面向对象的编码中,会动态进行代码织入操作,即系统在运行期间会修改或者增加字节码,这种情况下会导致类改变或者增加新的类,类需要重新加载,如果持续地有新类产生,可能会导致这块内存一直增加,直到这块内存溢出。

(3)Java进程本地内存,这是JVM用于其内部操作的内存。JVM使用的本地内存数量取决于生成的代码质量、创建的线程、GC期间用于保存java对象信息的内存,以及在代码生成、优化等过程中使用的临时空间。如果有一个第三方本地模块,那么它可能使用本地内存。例如,本地JDBC驱动程序将分配本地内存。最大本地内存量受到任何特定操作系统上的虚拟进程大小限制约束,也受到-Xmx标志指定用语java堆的内存量的限制。例如,如果应用程序能分配总计3GB的内存量,并且java堆的大小设为1GB,那么本地内存量的最大值可能2GB左右,即JVM使用的本地内存由如下几部分做成:
(a):Java.exe是C/C++写的程序,运行过程中自然需要内存,包括操作系统加载该程序,和java.exe运行过程中自己分配的内存。
(b):JNI调用动态库使用的内存,即JNI中调用new 或者malloc的内存等。

堆内存和Perm内存都可以通过参数设置它的大小,而本地内存的大小是不需要设置的,就像传统程序,内存的分配直接由操作系统从总的内存中分配。

3.3 object = null ?
把一个引用设为null的动机往往是逻辑的需要,而不是释放内存的需要。 比如:

public void clear() {
    modCount++;
    Entry[] tab = table;
    for (int i = 0; i < tab.length; i++)
    tab[i] = null;
    size = 0;
 }

上面代码是业务需要,并不是为了释放内存。

HashMap mapobj = new HashMap();
public void myfun(){

    String obj1 = new String("abcd");
    ...
    mapobj.put(obj1,obj1);
    ...
    obj1 = null;    
}

引用代码如下图:


refre_Image.png

实际上我们把obj1设为null,并没有回收"abcd",其还被hashmap引用,所以obj1设置为空只是将obj1的引用不指向任何内存。原本obj1的作用域就是在方法内,所以这种设置为空并不会清空其所指向的对象的物理内存。

四、内存设置:

堆:
指定初始化堆内存大小:-Xms:64m;
指定最大堆内存大小:-Xmx:1024m;

Perm:
指定初始化Perm内存大小:-XX:PermSize:64m;
指定最大Perm内存大小:-XX:MaxPermSize:1024m;

如果系统需要的堆内存确实很大,无法减少Xmx的设置,可以通过设置-Xss强行将每
个线程堆栈的尺寸设小,一旦线程堆栈过长,则自动截断,从而可以让线程堆栈占用
的内存不过渡膨胀。但这个效果往往有限的。

五、内存大小:

Java进程内存 = Java堆内存+本地内存+Perm内存。

相关文章

  • jvm堆栈内存介绍

    一、好言 礼貌是因为陌生 胡闹是因为熟悉。 二、背景 看书,摘抄的重点,总结,不过这个大部分都是摘抄的重点,提取...

  • 2021-01-05

    本文转载自公众号 占小狼的博客 说”JVM内存模型“,有人会说是关于JVM内存分布(堆栈,方法区等)这些介绍,也有...

  • JVM调优工具详解以及调优实战

    JVM工具 jmap jmap -histo > ./log.txt : 打印JVM堆栈内存信息,实例个数以及...

  • 什么是Java内存模型

    有个小伙伴提了一个问题: 有一个关于JVM名词定义的问题,说”JVM内存模型“,有人会说是关于JVM内存分布(堆栈...

  • Java开发

    JVM 内存溢出实例 - 实战 JVM(二) 介绍 JVM 内存溢出产生情况分析Java - 注解详解 详细介绍 ...

  • Flink源码阅读(六)--- Flink 内存模型

    本篇文章主要介绍下FLink的内存模型,在介绍Flink内存模型之前,我们首先学习下JVM内存结构 1. JVM内...

  • 2. Java内存模型

    Java内存模型指定了JVM和计算机内存是如何进行协作 Java内存模型的原理 Java内存被分为线程栈和堆栈:J...

  • 01__JVM(4)内容图

    JVM 常见 问题处理方式 保存堆栈快照日志 分析内存泄漏 调整内存设置 控制垃圾回收频率 选择合适的垃圾回收器 ...

  • JVM02——JVM运行时内存

    在上一篇文章中,我们介绍了 JVM 的内存区域,本文我们将继续围绕 JVM 展开话题,介绍 JVM 运行时内存。关...

  • Java 堆栈和OOM、SOF

    在介绍堆栈之前简单说下JVM的内存结构,一共分为虚拟机栈、堆、方法区、程序计数器、本地方法栈五个部分: 栈: 线程...

网友评论

      本文标题:jvm堆栈内存介绍

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