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命令,定位到具体哪两个(多个)线程出现死锁。

相关推荐
努力发光的程序员1 小时前
互联网大厂Java求职面试实录
java·jvm·线程池·多线程·hashmap·juc·arraylist
Tim_102 小时前
【C++入门】03、C++整型
java·开发语言·jvm
CodeAmaz3 小时前
JVM内存模型详解
jvm·内存模型
Da Da 泓8 小时前
多线程(四)【线程安全问题】
java·开发语言·jvm·学习·安全·多线程·线程安全问题
普通网友8 小时前
更优雅的测试:Pytest框架入门
jvm·数据库·python
li.wz9 小时前
JVM 执行引擎:从“能跑”到“跑得快”
jvm
没有bug.的程序员9 小时前
JVM 安全与沙箱深度解析
java·jvm·安全·gc·gc调优
Ryana9 小时前
协程不是银弹:历时半年,终于搞清了每分钟120次YGC的真相
jvm·后端
CodeAmaz10 小时前
JVM双亲委派模型详解
jvm·双亲委派