1 架构图
2 线程共享数据区
2.1 堆
用于存放对象实例
堆本身没有分区,所有的分区方法都只是逻辑分区,仅用于帮助理解,如:GC分为新生代、老年代、永久代、Eden等,线程可以有线程缓冲区
堆内存在物理上可以是不连续的,逻辑上连续即可。
2.2 方法区
用于存储被虚拟机加载的类型信息、常量、静态变量、即时编译后的代码缓存等数据。
方法区容易和“永久代”混淆
老版本中,为了方便,用堆的永久代方法实现方法区
java8中,完全舍弃永久代,用元空间实现方法区
永久代的约束宽松
不需要连续内存空间
可以固定大小,也可以可扩展
可以不实现垃圾回收(可能会导致内存溢出)
2.3 运行时常量
用于存储编译时期生成的各种字面量与符号引用
具有动态性:
不一定只有编译器生成,运行期间可新增,如:string的intern()方法
3 线程私有内存
3.1程序计数器
线程所执行的字节码的行号指示器
3.2 java虚拟机栈
描述Java方法执行的内存模型
方法被执行时,创建一个栈帧,用于存储局部变量表、操作数栈、动态连接、方法出口灯信息。
局部变量表存基本数据类型,对象只保存指针
局部变量表数量在编译时确定,运行时数量一旦分配不会改变
方法执行完毕,出栈
3.3 本地方法栈
与java虚拟机栈相同
唯一区别,为java虚拟机调用本地(Native)方法服务
4 直接内存
可以使用Native函数直接分配堆外内存
不受java堆大小限制,最大可以填满机器内存