JVM执行Java程序的过程中管理的内存空间

  JVM执行Java程序的过程中管理的内存空间,包括下列几个区域:

  程序计数器(Program CounterRegister)

  · 线程私有,占用空间很小。

  · 线程所执行代码行号指示器。

  · 解释器通过计数器的值选择下一条执行的字节码指令。

  · 线程执行Native方法时值为空。

  · 没有OOM(OutOfMemory)。Java虚拟机栈(Java Virtual Machine Stacks)

  · 线程私有。· 储存方法栈帧(Stack Frame)。

  · 栈帧:储存局部变量表、操作栈、动态链接、方法出口等。

  · 局部变量表:编译器可知的基本类型、对象引用和returnAddress(字节码指令的地址)。在编译期间完成分配,运行时大小不变。

  本地方法栈(Native MethodStacks)

  · 线程私有,类似虚拟机栈。

  · 服务Native方法。

  · 同样存在StackOverflowError和OOM。

  · Hotspot中将Java虚拟机栈和本地方法栈合二为一,通过-Xss设置大小。JDK1.6以前默认256K,1.6默认1M。

  Java堆(Java Heap)

  · 所有线程共享。

  · 储存对象实例。

  · GC和OOM的主要区域。

  Heap OOM例子:

  ·

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值