1.JVM内存结构
类加载器子系统,运行时数据区,执行引擎

  1. 运行时数据区包括:方法区、虚拟机栈、本地方法栈、虚拟机栈、程序计数器
    方法区:用于储存已被虚拟机加载的类信息、常量、静态变量等。
    虚拟机栈:用于储存局部变量表、操作数栈、动态链接,方法出口等。
    本地方法栈:虚拟机栈执行Java方法服务,本地方法栈为虚拟机使用到native方法服务。
    Java堆:存放对象实例,垃圾收集器管理的主要区域。
    程序计数器:主要用于记录当前线程执行到那块。

2.区别
1)管理方式不同,栈由操作系统自动分配释放,无需手动控制。
堆的申请和释放工作由程序员控制,容易产生内存泄漏。
2)空间大小不同,栈远大于堆
3)分配方式不同。堆都是动态分配,站有两种分配方式:静态分配、动态分配
堆的动态分配由操作系统进行释放。
4)分配效率不同,压栈、出栈都有专门的指令进行,这决定了栈的效率要高。
3.堆的结构
Java 7:新生区+养老区+永久区
Java 8:新生区+养老区+元空间

标签: Java, 虚拟机, 内存, 方法, JVM, 分配, 结构, 动态分配

相关文章推荐

添加新评论,含*的栏目为必填