zoukankan      html  css  js  c++  java
  • java程序执行时内存变化图解

    程序执行的内存分析过程
    为了让初学者顺利的分析内存,更加容易的体会程序执行过程中内存的变化,加深理解。我们将JAVA虚拟机内存模型进行简化。

    在本节课中,Java虚拟机的内存可以简单的分为三个区域:虚拟机栈stack、堆heap、方法区method area

    虚拟机栈(简称:栈)的特点如下:
    1.栈描述的是方法执行的内存模型。每个方法被调用都会创建一个栈帧(存储局部变量、操作数、方法出口等)
    2.JVM为每个线程创建一个栈,用于存放该线程执行方法的信息(实际参数、局部变量等)
    3.栈属于线程私有,不能实现线程间的共享!
    4.栈的存储特性是“先进后出,后进先出”
    5.栈是由系统自动分配,速度快!栈是一个连续的内存空间!
    堆的特点如下:
    1.堆用于存储创建好的对象和数组(数组也是对象)
    2.JVM只有一个堆,被所有线程共享
    3.堆是一个不连续的内存空间,分配灵活,速度慢!
    方法区(又叫静态区,也是堆)特点如下:
    1.方法区是JAVA虚拟机规范,可以有不同的实现。
    i.JD7以前是“永久代”
    ii.JDK7部分去除“永久代”,静态变量、字符串常量池都挪到了堆内存中
    iii.JDK8是“元数据空间”和堆结合起来。
    2.JVM只有一个方法区,被所有线程共享!
    3.方法区实际也是堆,只是用于存储类、常量相关的信息!
    4.用来存放程序中永远是不变或唯一的内容。(类信息【Class对象,反射机制中会重点讲授】、静态变量、字符串常量等)
    例子:
    public class Person {
    String name;
    int age;
    public void show(){
    System.out.println(“姓名:”+name+",年龄:"+age);
    }
    }

    public class TestPerson {
    public static void main(String[ ] args) {
    // 创建p1对象
    Person p1 = new Person();
    p1.age = 24;
    p1.name = “张三”;
    p1.show();
    // 创建p2对象
    Person p2 = new Person();
    p2.age = 35;
    p2.name = “李四”;
    p2.show();
    }
    }

    1.首先,在方法区加载person类,程序从mian()方法开始执行main()方法加载到栈内存。
    2.然后,main()方法中,创建对象p1,person()构造方法加载到栈内存,在堆内存中开辟出一个内存块地址为0x11(这里是随意命名)赋值,name:null,age:0.执行完毕,person()构造方法从栈内存移除。
    3.在main()方法中继续执行,给age赋值为24,给name赋值为“张三”.调用show()方法,show()方法加载到堆内存。输出内容“张三,24”,show()方法执行完毕从栈内存移除。
    4.创建对象p2,person()构造方法加载到栈内存,在堆内存中开辟出一个内存块地址为0x12(这里是随意命名)赋值,name:null,age:0.执行完毕,person()构造方法从栈内存移除。
    5.继续执行,给age赋值为35,给name赋值为“李四”.调用show()方法,show()方法加载到堆内存。输出内容“李四,35”,show()方法执行完毕从栈内存移除。
    6.main()方法执行完毕,从栈内存移除。

  • 相关阅读:
    开发中几个时期该写的
    Java API Docs
    Cogs 1709. [SPOJ705]不同的子串 后缀数组
    Poj 3683-Priest John's Busiest Day 2-sat,拓扑排序
    Bzoj 1616: [Usaco2008 Mar]Cow Travelling游荡的奶牛 动态规划
    Bzoj 1856: [Scoi2010]字符串 卡特兰数,乘法逆元,组合数,数论
    Bzoj 1624: [Usaco2008 Open] Clear And Present Danger 寻宝之路 最短路,floyd
    Bzoj 1042: [HAOI2008]硬币购物 容斥原理,动态规划,背包dp
    Bzoj 2393: Cirno的完美算数教室 容斥原理,深搜
    Bzoj 1853: [Scoi2010]幸运数字 容斥原理,深搜
  • 原文地址:https://www.cnblogs.com/sea520/p/13182614.html
Copyright © 2011-2022 走看看