栈和栈帧
- JVM中的栈内存,就是给线程使用的,每个线程启动后,JVM就会为其分配一块栈内存。
- 每个栈由多个栈帧(Frame)组成,对应着每次方法调用时所占用的内存
- 每个线程只能有一个活动栈帧,对应着当前正在执行的方法。
线程上下文切换(Thread Context Switch)
因为某些原因,CPU不再执行当前线程,转而执行另一个线程的代码。
这些原因可能是:
- 线程的CPU时间片用完
- 垃圾回收,工作线程需要暂停
- 有更高优先级的线程需要运行
- 线程自己调用了sleep、yield、wait、join、park、synchronized、lock等方法
当线程上下文切换时,需要由操作系统保存当前线程的状态,并恢复另一个线程的状态,java中对应的概念就是程序计数器,它的作用是记住下一条要执行的JVM指令的地址,程序计数器是线程私有的。
- 状态包括程序计数器、虚拟机栈中每个栈帧的信息,如局部变量、操作数栈、返回地址等。
- 频繁的上下文切换会影响性能
622

被折叠的 条评论
为什么被折叠?



