您的位置:首页 > 编程语言 > Java开发

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

2015-10-29 10:33 295 查看
  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例子:

  ·
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: