JVM--虚拟机栈
- 栈:每个线程运行时所需要的内存为虚拟机栈,每个线程对应一个栈。数据结构特点是先进后出(类比子弹夹),
- 栈桢:每个栈由多个栈桢(Frame)组成。当执行一个方法的时候,会把这个方法的参数、局部变量、返回地址等压入栈,这块内存区域,称之为栈桢,当方法运行结束的时候从栈中弹出。
- 每个线程只能有一个活动栈桢,对应着当前正在执行的那个方法(顶部的栈桢)
-
示例
注意事项:
- 垃圾回收不需要回收栈内存,因为会自动弹出
- 栈空间大小可以使用-Xss size设置,除windows外,其他操作系统默认为1024KB。栈越大,可使用的线程就越少。
- 方法内的局部变量是线程安全的。但如果局部变量引用了引用类型的参数对象,或返回值为引用类型对象,者是线程不安全的,因为可能会有多个线程在外部有对其进行修改。
-
栈内存溢出: java.lang.StackOverflowError
- 栈桢数量过多,比如递归调用,ObjectMapper转json字符串时,实体属性的引用有相互包含关系等。
- 栈桢过大(不太可能出现,因为很难有超过1024KB的栈桢)