欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JVM运行时的内存划分--JDK1.8

程序员文章站 2022-10-18 10:43:53
对比JDK1.7,JDK1.8在运行时的内存分配上进行了调整。本篇对JDK1.8版本进行简要介绍。 先以一张图片描述运行时内存: 程序计数器 记录当前线程执行的字节码行号。如果执行的是native方法,值为null。 虚拟机栈 每一个线程执行时,都对应有一个虚拟机栈,生命周期与线程相同。一个虚拟机栈 ......

  对比jdk1.7,jdk1.8在运行时的内存分配上进行了调整。本篇对jdk1.8版本进行简要介绍。

  先以一张图片描述运行时内存:

  JVM运行时的内存划分--JDK1.8

程序计数器

  记录当前线程执行的字节码行号。如果执行的是native方法,值为null。

虚拟机栈

  每一个线程执行时,都对应有一个虚拟机栈,生命周期与线程相同。一个虚拟机栈有一个一个的栈帧组成,每个java方法被调用时都会创建一个栈帧,然后入栈,方法结束后出栈。一个栈帧由局部变量表,操作数栈,动态链接和方法出口信息组成。

  如果方法中出现递归调用死循环,或者栈帧大小超过虚拟机栈限制都会抛出*error;

  JVM运行时的内存划分--JDK1.8

 本地方法栈

  功能与虚拟机栈差不多,只不过本地方法栈是虚拟机在调用native方法时使用。


  堆是jvm占用比例最大的一块区域,用来存放对象实例。现代jvm大多将堆分为老年代和新生代。老年代与新生代比例为2:1。新生代分为一个eden和两个survivor区域,比例为8:1:1。

  jdk1.7之后,运行时常量池从方法区中移入到堆中,存放一些符号引用。

元数据区
  在jdk1.7的时候,有一个jvm内存区域中有一块方法区,主要存放虚拟机加载的类信息,静态变量,常量等。

  jdk1.8时,移除了方法区的概念,用一个元数据区代替。元数据区存放的东西和方法区相同,不过元数据区移动到本地内存中。本地内存,又称堆外内存(direct memory),就是指机器内存中不是jvm管理的那部分内存,由操作系统管理。元数据区移动到本地内存以后,可以避免虚拟机加载类过多而引发的内存溢出:java.lang.outofmemoryerror: permgen,但是同样不能无限扩展。

jvm常用参数

  • -xms64m 最小堆内存 64m
  • -xmx128m 最大堆内存 128m
  • -xx:newsize=30m 新生代初始化大小为30m
  • -xx:maxnewsize=40m 新生代最大大小为40m
  • -xss=256k 线程栈大小
  • -xx:initialsurvivorratio 新生代eden/survivor空间的初始比例
  • -xx:newratio 新生代和老年代的内存比例
  • -xx:maxmetaspacesize 元数据区最大内存