JVM-虚拟机栈

一、概念

Java虚拟机栈是Java虚拟机内存结构中的一部分,是每个线程运行的内存空间。每个虚拟机栈由多个栈帧组成,每次调用一个方法会创建一个新的栈帧。

二、栈内存溢出

由于栈帧过多,导致栈帧所用的内存之和超出了给栈分配的内存,造成了StackOverflow错误。用-Xss参数可以设置栈的大小,例如-Xss256k表示设置栈的大小是256k字节

三、线程运行诊断
案例1:CPU占用过高
  1. 用top命令找到哪个进程占用CPU过高;
  2. ps H -eo pid, tid, %CPU | grep 进程id,定位到该进程中哪个线程占用CPU过高;
  3. jstack 进程id,会打印进程当前线程的堆栈信息,可以根据占用CPU高的线程id进一步定位到源代码的某文件-某行存在问题。
案例2:长时间没有返回结果(出现死锁)

也可以用jstack 进程id命令,定位到具体哪两个(多个)线程出现死锁。

相关推荐
IT龟苓膏5 分钟前
Java 并发基础:进程、线程、线程状态、synchronized、volatile 一篇讲清
java·开发语言·jvm
周末也要写八哥1 小时前
线程的生命周期之线程睡眠
java·开发语言·jvm
瓦特what?2 小时前
位运算核心技巧与应用
java·jvm·算法
程序员二叉3 小时前
【JVM】类加载全过程&双亲委派机制深度解析
java·jvm·面试
cfm_29143 小时前
JVM 深度入门:Class文件结构 + 字节码指令详解
jvm
吴声子夜歌3 小时前
JVM——线程池实现原理
java·jvm·线程池
Full Stack Developme3 小时前
JVM的类加载机制
jvm
fengxin_rou4 小时前
Java垃圾回收机制深度解析:从原理到实战
java·jvm·性能优化·gc·垃圾回收
cfm_29144 小时前
Java JVM 零基础入门
java·jvm
wuminyu6 小时前
Java锁机制之park与futex系统级协同机制解析
java·linux·c语言·jvm·c++