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例子:
·