- 首先如果不指定堆的大小,取决于电脑内存,可应用
jmap -heap pid
来确认。默认大小为内存的四分之一。
-Xms
堆的初始大小,-Xmx
堆的最大值,-Xmn
新生代的大小。堆分为新生代和老年代两块内存,默认新生代和老年代占比为 1:2。
简直
所有的对象都在堆上分配内存,但不是相对,非凡状况下对象能够在栈上调配的。
- 如果堆上没有内存给新生对象调配了,并且又没有垃圾回收空出内存,就会产生 OOM 内存溢出。
- 用于存储运行时常量池、已被虚拟机加载的类信息、常量、动态变量、即时编译器编译后的代码等数据。
- 当办法区无奈满足内存调配需要时,将抛出 OOM 异样。
- 一个线程有一个本人的栈。默认栈的大小为 1M,能够通过
-Xss
来设置栈的大小。
- 线程走过的每个办法,都合乎 FILO,每个办法都叫一个办法栈帧,每个栈帧都会蕴含:局部变量表、操作数栈、动静链接、返回地址。
- 如果线程申请的栈深度大于虚拟机所容许的深度,将抛出 StackOverflowError 异样。
- 为 JVM 所调用到的 Nativa 办法,即本地办法服务。
- JVM 的多线程是通过线程轮流切换并调配处理器来实现的,看起来的并行,事实上是一个处理器也只会执行一条线程中的指令。所以,为了保障各线程指令的平安顺利执行,每条线程都有独立的公有的程序计数器,为的就是能记录每个线程具体执行到代码哪一行了,不便下次继续执行。
- 此内存区域是惟一一个在 JVM 上不会产生 OOM 的区域。