详解Jvm内存结构

详解Jvm内存结构近期在学习研究内存,那么Jvm内存结构和Jvm的内存模型即JMM(Javamomerymodel)这两项内容都是学习java虚拟机、java内存知识的基础。为了让自己加深理解,有不至于嵌入到底层细节太深,会通过一段代码片段类比到内存结构图中的真实呈现。一、Jvm体系的内存结构图JVM运行数据区,也就是我们所说的内存结构主要分为两个大区:1、线程共享区**方法区(MethodArea)????*存储运行时的常量池、被虚拟机加载过的类信息、常量、静态变量、即时编译器编译后的代码数据。**堆区(

大家好,又见面了,我是你们的朋友全栈君。

近期在学习研究内存,那么Jvm内存结构和Jvm的内存模型即JMM(Java momery model)这两项内容都是学习java虚拟机、java内存知识的基础。为了让自己加深理解,有不至于嵌入到底层细节太深,会通过一段代码片段类比到内存结构图中的真实呈现。

一、Jvm体系的内存结构图

详解Jvm内存结构

JVM运行数据区,也就是我们所说的内存结构主要分为两个大区:

1、线程共享区

**方法区(Method Area)?*存储运行时的常量池、被虚拟机加载过的类信息、常量、静态变量、即时编译器编译后的代码数据。

**堆区(Heap Area)?*所有的对象实例以及数组都要在堆上分配,也是垃圾回收器主要管理的对象。

2、线程独占区

**虚拟机栈:**又称Java栈,存储局部变量表、操作栈、动态链接、方法出口,对象指针。

**本地方法栈:**为虚拟机使用到的Native 方法服务。如Java使用c或者c++编写的接口服务时,代码在此区运行,Android中的Jni本地方法调用亦该如此。

**程序计数器:**当前线程执行的字节码的行号指示器。

接下来我们通过一段简单的代码来看实际内存结构图

二、内存结构图实例分析

先看实例代码:

public class MemoryStructure { 
   
    static  int sSize =10;//静态变量 方法区
    static MemoryObj memoryObj=new MemoryObj(sSize);//声明部分(静态类变量)放在方法区,对象实例在堆中
    int initSize=20;//类的成员变量 堆区
    MemoryObj memoryObj2=new MemoryObj(initSize);//声明部分(引用类型成员变量),实例都在 堆中
    public static void main(String[] args) { 
   
        //MemoryStructure memoryStructure 声明部分(引用类型) 放在虚拟栈
        MemoryStructure memoryStructure = new MemoryStructure();
        int size3=30;//栈区
        //MemoryObj memoryObj3声明部分(引用类型) 放在虚拟栈
        MemoryObj memoryObj3= new MemoryObj(size3);

        //新开线程 :新的独享虚拟栈
        new Thread(){ 
   
            @Override
            public void run() { 
   
                int k=40;//栈区
                setSize(40);
            }

            void setSize(int size){ 
   
                memoryStructure.memoryObj2.size=size;
                //说明:
                //新线程访问主线程的局部变量是无法访问的,当前编译器没有报错,是因为idea工具编译做了处理
                //查看一下编译后的字节码: final MemoryObj memoryObj3 = new MemoryObj(size3); 
                MemoryObj temp=memoryObj3;
            }
        }.start();
    }
}

class MemoryObj{ 
   
    int size;
    public MemoryObj(int size) { 
   
        this.size = size;
    }
}

上述代码,对照内存结构图的分布位置如下:

详解Jvm内存结构

正如代码中的注释和上述代码片段在各区中的分布图,能很清晰的知晓Jvm的内存结构。

补充一些堆和方法区的理解,虽然Java 虚拟机规范把方法区描述为堆的一个逻辑部分,但是它却有一个别名叫做Non-Heap(非堆),目的应该是与Java 堆区分开来。

方法区是为类信息服务的,存储类信息、常量、静态变量。成员变量直接存在在堆中。

虚拟栈区可以理解成为程序的执行服务的,方法中定义的局部变量,被保存在这个位置,最终方法的执行是通过出栈压栈的方式执行。

方法区、堆区是共享区域;虚拟栈区是独享区域

每一个线程都会对应一个虚拟栈(又称java栈),上述newThread中的MemoryObj temp=memoryObj3;,若memoryObj3是无final修饰,是无法直接访问的,栈内数据是独享的。

这篇是通过一个实例分析的方式,对jvm的内存结构有了更清晰的认识。如若想做更深度的了解,推荐《深入理解 Java 虚拟机》这本书籍。
获得更多更新,关注gongzhonghao:Hym4Android
详解Jvm内存结构

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/140576.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • QTreeWidget 遍历所有子节点(QTreeWidgetItem)[通俗易懂]

    QTreeWidget 遍历所有子节点(QTreeWidgetItem)[通俗易懂]这恐怕是最简单的写法了,逛论坛发现的,亲测好用//ui文件中定义//QTreeWidget*treeWidget;//…//遍历treeWidgetQTreeWidgetItemIteratorit(ui.treeWidget);while(*it){//dosomethinglike…

  • navicat激活码2021【2021最新】

    (navicat激活码2021)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~https://javaforall.cn/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~DB…

  • 集合基数[通俗易懂]

    集合基数[通俗易懂]通俗的说,集合的势是量度集合所含元素多少的量。集合的势越大,所含的元素越多。定理9.1设A,B,C是任意集合,(1)A≈A。(2)若A≈B,则B≈A。(3)若A≈B,B≈C,则A≈C。定义9.2(1)设A,B是集合,如果存在从A到B的单射函数,就称B优势于A,记作A·B。如果B不是优势于A,则记作A·B。(2)设A,B是集合,若A·B且AB,则称B真优势于A,记作A·B。如果B不是真优势于A,则记作A·B。关于DiscreteMathematics更多讨论与交流,敬请关注本博客和新浪微博s

  • JUC多线程:线程池的创建及工作原理

    JUC多线程:线程池的创建及工作原理

  • eclipse import导入报错_project2016安装出错

    eclipse import导入报错_project2016安装出错【转载请注明出处:http://blog.csdn.net/zjbpku/article/details/7370347】本文只介绍方法不解释原因:0,如果R.layout.main有误,将importandroid.R删除一,删除gen文件,会自动生成一个新的gen(Project下的BuildAutomatically要选上)二、右键点击有误文件,选择BuildP

  • OHEM算法

    OHEM算法版权声明:本文为博主原创文章,未经博主允许不得转载。https://blog.csdn.net/u014380165/article/details/73148073…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号