JVM(三)—— 重新认识内存分析

电脑内存分布:

 JVM内存分析:

 
区域分析:

引擎区:引擎执行加载等过程需要内存

方法区:存放类信息、常量、静态变量,即类对象,也称为永久代/permgen space/non-heap

栈区:包含本地方法栈和java方法栈,是执行代码所占的内存,heap

堆区:堆存放的是对象,包含新生代和老年代,其中新生代又分为edens1s2


下面通过以下这个java程序,来说明java程序从编译到最后运行的整个流程。代码如下:

public class TestMain{  
    public static void main(String[] args) {  
        Animal animal = new Animal("Puppy");  
        animal.printName();  
    }  
}  
//Animal.java  
public class Animal {  
    public String name;  
    public Animal(String name) {  
        this.name = name;  
    }  
    public void printName() {  
        System.out.println("Animal ["+name+"]");  
    }  
}  
下面是程序运行的详细步骤:  
       在编译好java程序得到TestMain.class文件后,在命令行上敲java TestMain。系统就会启动一个jvm进程,jvm进程从classpath路径中找到一个名为TestMain.class的二进制文件,将TestMain的类信息加载到运行时数据区的方法区内,这个过程叫做TestMain类的加载。
      然后JVM找到TestMain的主函数入口,开始执行main函数。      main函数的第一条命令是Animal  animal = new Animal("Puppy");就是让JVM创建一个Animal对象,但是这时候方法区中没有Animal类的信息,所以JVM马上加载Animal类,把Animal类的类型信息放到方法区中。
      加载完Animal类之后,Java虚拟机做的第一件事情就是在堆区中为一个新的Animal实例分配内存, 然后调用构造函数初始化Animal实例,这个Animal实例持有着指向方法区的Animal类的类型信息(其中包含有方法表,java动态绑定的底层实现)的引用。当使用animal.printName()的时候,JVM根据animal引用找到Animal对象,然后根据Animal对象持有的引用定位到方法区中Animal类的类型信息的方法表,获得printName()函数的字节码的地址。
       开始运行printName()函数。
总结
      大牛讲过课后,果然收获良多。这其中还有好多东西需要理解,比如一个对象的一生经历,垃圾回收机制,类文件结构,报错与内存分析等。下篇文章是垃圾回收机制和java代码报错分析。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 12
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值