JVM--虚拟机栈

JVM--虚拟机栈

  1.  栈:每个线程运行时所需要的内存为虚拟机栈,每个线程对应一个栈。数据结构特点是先进后出(类比子弹夹),
  2. 栈桢:每个栈由多个栈桢(Frame)组成。当执行一个方法的时候,会把这个方法的参数、局部变量、返回地址等压入栈,这块内存区域,称之为栈桢,当方法运行结束的时候从栈中弹出。
  3. 每个线程只能有一个活动栈桢,对应着当前正在执行的那个方法(顶部的栈桢)
  • 示例

JVM--虚拟机栈

注意事项:

  1. 垃圾回收不需要回收栈内存,因为会自动弹出
  2. 栈空间大小可以使用-Xss size设置,除windows外,其他操作系统默认为1024KB。栈越大,可使用的线程就越少。
  3. 方法内的局部变量是线程安全的。但如果局部变量引用了引用类型的参数对象,或返回值为引用类型对象,者是线程不安全的,因为可能会有多个线程在外部有对其进行修改。
  • 栈内存溢出: java.lang.StackOverflowError

  1. 栈桢数量过多,比如递归调用,ObjectMapper转json字符串时,实体属性的引用有相互包含关系等。
  2. 栈桢过大(不太可能出现,因为很难有超过1024KB的栈桢)