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

相关推荐
隐退山林37 分钟前
JavaEE:多线程初阶(二)
java·开发语言·jvm
期待のcode2 小时前
Java虚拟机堆
java·开发语言·jvm
alonewolf_9911 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
weixin_4657909112 小时前
电动汽车有序充电:电网负荷削峰填谷的新利器
jvm
ProgramHan13 小时前
Spring Boot 3.2 新特性:虚拟线程的落地实践
java·jvm·spring boot
小当家.10516 小时前
深入理解JVM:架构、原理与调优实战
java·jvm·架构
栗子叶17 小时前
Java对象创建的过程
java·开发语言·jvm
2501_9167665418 小时前
【JVM】类的加载机制
java·jvm
芒克芒克1 天前
虚拟机类加载机制
java·开发语言·jvm
alonewolf_991 天前
JDK17 GC调优全攻略:从参数解析到实战优化
java·jvm