-
jvm结构图:
-
程序计数器(寄存器):
-
作用:
记住下一条jvm指令的执行地址。 -
特点:
- 线程私有(每个线程都有属于自己的程序计数器。线程暂停后,再次执行时需要计数器)
- 不存在内存溢出
-
-
虚拟机栈:
-
什么是虚拟机栈?
- 栈是指线程运行需要的内存空间。
- 栈由多个栈帧(每个方法运行时需要的内存)组成。栈帧内包含参数、局部变量和返回地址。
- 栈内的多个栈帧遵循先进后出原则,每个线程只能有一个活动栈帧,对应着当前正在执行的那个方法。
- 扩展:
- 垃圾回收不涉及栈内存,因为栈内存在每个线程执行完成后自动回收。
- 栈内存通过配置:-Xss参数修改,linux、macos、oracle默认都是1024kb,windows根据情况。
- 方法内部的局部变量,在不超出方法有效范围内修改时,默认线程安全的。
-
栈内存溢出的情况?
- 栈帧过多:方法递归调用没有出口会导致栈栈帧创建过多,从而内存溢出。
- 栈帧过大:局部变量过多、局部变量互相引用转json。
-
栈/线程运行如何诊断?
- cpu占用过多:
- top查看进程对cpu占用情况。
- ps(展示) H -eo(展示哪些字段) pid,tid,%cpu | grep 进程id
- jstack 进程id(展示进程中java线程运行情况 treed0、treed1等是用户编写的进程)
- 其他:top -Hp pid可以查看线程占用。jstack或者jconsole
- 程序长时间没有响应:
- jstack最后会有found one java -level deadlock,即查找到又一个java死锁
- cpu占用过多:
-
-
本地方法栈
- Native Method Stacks
- java虚拟机调用本地方法时使用的内存,非java代码编译的方法,可以直接与操作系统直接交互的代码。
-
堆(Heap)
jvm学习
于 2024-08-08 16:21:33 首次发布