关于java:JVM运行时数据区

2次阅读

共计 630 个字符,预计需要花费 2 分钟才能阅读完成。

JVM 运行时数据区

线程共享

JAVA 堆

  • 首先如果不指定堆的大小,取决于电脑内存,可应用 jmap -heap pid 来确认。默认大小为内存的四分之一。
  • -Xms堆的初始大小,-Xmx堆的最大值,-Xmn新生代的大小。堆分为新生代和老年代两块内存,默认新生代和老年代占比为 1:2。
  • 简直 所有的对象都在堆上分配内存,但不是相对,非凡状况下对象能够在栈上调配的。
  • 如果堆上没有内存给新生对象调配了,并且又没有垃圾回收空出内存,就会产生 OOM 内存溢出。

办法区

  • 用于存储运行时常量池、已被虚拟机加载的类信息、常量、动态变量、即时编译器编译后的代码等数据。
  • 当办法区无奈满足内存调配需要时,将抛出 OOM 异样。

线程独享

虚拟机栈

  • 一个线程有一个本人的栈。默认栈的大小为 1M,能够通过 -Xss 来设置栈的大小。
  • 线程走过的每个办法,都合乎 FILO,每个办法都叫一个办法栈帧,每个栈帧都会蕴含:局部变量表、操作数栈、动静链接、返回地址。
  • 如果线程申请的栈深度大于虚拟机所容许的深度,将抛出 StackOverflowError 异样。

本地办法栈

  • 为 JVM 所调用到的 Nativa 办法,即本地办法服务。

程序计数器

  • JVM 的多线程是通过线程轮流切换并调配处理器来实现的,看起来的并行,事实上是一个处理器也只会执行一条线程中的指令。所以,为了保障各线程指令的平安顺利执行,每条线程都有独立的公有的程序计数器,为的就是能记录每个线程具体执行到代码哪一行了,不便下次继续执行。
  • 此内存区域是惟一一个在 JVM 上不会产生 OOM 的区域。
正文完
 0