JVM运行时数据区中栈、堆,程序计数器、元空间,的特点及作用

jvm内存结构划分

2.jvm运行时数据区 程序计数器的特点及作用:

1.程序计数器是一块较小的内存空间,几乎可以忽略;

2.是当前线程所执行的字节码的行号指示器;

3.Java多线程执行时,每条线程都会有一个独立的程序计数器,各条线程之间互不影响;

4.该区域是“线程私有”的内存,每个线程独立存储;

5.该区域不存在OOM;

6.无GC回收

3.jvm运行时数据区 虚拟机栈的特点及作用:

1.线程私有

2.方法执行会创建栈帧,存储局部变量表等信息;

3.方法执行遵循(先进后出)FILO;

4.栈深度大于虚拟机所允许会抛出栈溢出 StackOverflowError

5.栈需要扩展而无法申请空间OutOfMemoryError;---hostspot虚拟机没有

6.栈里面运行方法,存放方法的局部变量名,变量名所指向的值都存在堆上;

7.栈一般不设置大小,栈所占的空间很小,可通过-Xss1M设置,如果不设置,默认为1M

8.随线程而生,随线程而灭

9.该区域不会GC

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JVM运行数据区是指在JVM进程运行过程中,用于存储数据的各个区域,包括以下几个部分: 1. 程序计数器(Program Counter Register):线程私有的区域,用于记录当前线程执行的字节码行号,以便线程在执行过程中能够从正确的位置继续执行。 2. Java虚拟机JVM Stack):线程私有的区域,用于存储方法的帧(Stack Frame),包括局部变量表(Local Variable Table)、操作数(Operand Stack)、动态链接(Dynamic Linking)、方法出口(Return Address)等信息。当一个方法被调用JVM会在中为该方法分配一个帧,方法执行完毕后,帧被出JVM继续执行上一个帧中的方法。 3. 本地方法(Native Method Stack):与Java虚拟机类似,用于存储本地方法的帧,本地方法是指使用本地语言(如C语言)编写的方法,本地方法与Java虚拟机的区别在于,本地方法用于执行本地方法,而Java虚拟机用于执行Java方法。 4. 堆(Heap):所有线程共享的区域,用于存储对象实例。在JVM启动,会分配一定大小的堆空间,当堆空间不足JVM会自动进行垃圾回收以释放无用的对象,从而维持堆空间的稳定。 5. 方法区(Method Area):所有线程共享的区域,用于存储类的元数据信息,包括类名称、访问修饰符、常量池、字段描述符、方法描述符等信息。在JDK8及以前的版本中,方法区也包括永久代(Permanent Generation),用于存储一些与类加载、字符串常量等相关的信息。在JDK8及以后的版本中,永久代被移除,取而代之的是Metaspace(元空间),用于存储类的元数据信息。 6. 运行常量池(Runtime Constant Pool):方法区的一部分,用于存储编译期生成的各种字面量(Literal)、符号引用(Symbolic Reference)等信息。在方法调用JVM会将运行常量池中的字面量、符号引用等信息加载到操作数中,供指令使用。 除了以上几个区域外,还有一些其他的区域,例如直接内存(Direct Memory),用于存储通过NIO(New IO)库分配的堆外内存。JVM运行数据区域对于Java程序的执行起到了关键的作用,了解这些区域有助于我们更好地理解Java程序的执行过程和内存管理机制。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值