有不少Java开发人员一提到Java内存结构,就会非常粗粒度地将JVM中的内存区理解为仅有Java堆(heap)和Java栈(stack)?
Java虚拟机栈(Java Virtual Machine Stack),早期也叫Java栈。每个线程在创建时都会创建一个虚拟机栈,其内部保存一个个的栈帧(Stack Frame),对应着一次次的Java方法调用。
是线程私有的
生命周期和线程一致。
栈是一种快速有效的分配存储方式,访问速度仅次于程序计数器。
如何理解栈管运行,堆管存储?
主管Java程序的运行,它保存方法的局部变量(8种基本数据类型、对象的引用地址)、部分结果,并参与方法的调用和返回。
局部变量 vs 成员变量(或属性)
基本数据变量 vs 引用类型变量(类、数组、接口)
即:栈解决程序的运行问题,即程序如何执行,或者说如何处理数据。堆解决的是数据存储的问题,即数据怎么放、放在哪儿。
不存在GC ; 存在OOM
StackOverFlowError?OutOfMemoryError?
Java 虚拟机规范允许Java栈的大小是动态的或者是固定不变的。
如果采用固定大小的Java虚拟机栈,那每一个线程的Java虚拟机栈容量可以在线程创建的时候独立选定。如果线程请求分配的栈容量超过Java虚拟机栈允许的最大容量,Java虚拟机将会抛出一个 StackOverflowError 异常。
如果Java虚拟机栈可以动态扩展,并且在尝试扩展的时候无法申请到足够的内存,或者在创建新的线程时没有足够的内存去创建对应的虚拟机栈,那Java虚拟机将会抛出—个 OutOfMemoryError 异常。
一般默认为512k-1024k,取决于操作系统。
栈的大小直接决定了函数调用的最大可达深度。
Java中,栈的大小通过什么参数来设置? (阿里)
设置的栈空间值过大,会导致系统可以用于创建线程的数量减少。
一般一个进程中通常有3000-5000个线程。
码字不易,还请点个赞和收藏~