深入理解jvm之java内存管理

前言

java虚拟机在java执行的时候会把java分为若干个不同的数据区域,即运行时数据区:
所有线程共享的区域:方法区(method area),堆(heap)
线程隔离的数据区:虚拟机栈(VM stack),本地方法栈(native method stack),程序计数器(program counter register)

1,方法区

方法区用来存储已经被虚拟机加载的类信息,常量,静态变量,即时编译器编译后的代码等数据。
运行时常量池(runtime constant pool)是方法区的一部分。class文件中有一项信息是常量池(constant pool table),用于存放编译时期出现的各种字面量(文本字符串,final常量值)和符号引用(字段和方法的名称和描述符,类和接口全限定名)。这部分内容将在类加载后进入方法区的运行时常量池中存放
运行时常量池具有动态性,常量不一定只有编译期才能产生,运行时也可以将新的常量放入。

2,java堆

java堆在虚拟机启动时创建,是虚拟机管理的内存最大的一块,这里存放几乎所有的对象实例以及数组
堆是垃圾收集器管理的主要区域,也叫GC堆。堆可分为新生代(新对象一般情况先放入新生代中)
和老年代(存活时间较久的对象)。它可以物理上不连续的存储空间,但是逻辑上要。

3 ,java虚拟机栈

java虚拟机栈是线程私有的,生命周期与线程相同。他描述的是java方法执行的内存模型,一个方法就会创建一个栈帧(stack frame),存放局部变量表,,操作数帧,动态链接,方法出口等信息。一个方法从调用到执行完成的过程就对应一个栈帧在虚拟机栈中入栈到出栈的过程。想象一下在一个递归函数中,就相当于从开始到后面执行的方法一个个压入栈中,直到最后一个方法满足条件不再递归,执行完成弹出栈,接着执行下面的方法并弹出,最后栈中只剩一个最开始的方法。执行完成后弹出栈。
局部变量表:存入编译时期可知的各种基本数据类型和对象引用,他所需的内存空间在编译时期完成内存分配,进入一个方法时,他的空间是确定的。在方法运行时期不会改变局部变量表小

4,本地方法栈

本地方法栈与虚拟机栈原理类似,只是虚拟机栈是为java方法(字节码)服务的,而本地方法栈是为了使用到的native方法服务。甚至有些虚拟机直接将他们合二为一

5,程序计数器

他是很小的一块空间,可以看成当前线程所执行字节码的行号指示器,每个线程都需要一个独立的程序计数器。如果正在执行native方法,那计数器值为空。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值