什么是上下文切换
CPU通过分配时间片来执行线程,当一个线程的时间片用完,就会切换到另一个线程。在切换前会保存上一个线程的状态,当下次再切换到该任务,就会加载这个状态,俗称保存现场和恢复现场。
线程从保存到再加载的过程就是一次上下文切换。
多个线程上下文切换过程
多个线程上下文切换
//示例
public static void main(String[] args) throws InterruptedException {
Thread t1 = new Thread(new Runnable() {
@Override
public void run() {
for (int i = 0; i < 10; i++) {
System.out.println("t1执行"+i);
}
}
},"t1");
Thread t2 = new Thread(new Runnable() {
@Override
public void run() {
for (int i = 0; i < 10; i++) {
System.out.println("t2执行"+i);
}
}
},"t2");
t1.start();
t2.start();
System.out.println("main线程执行");
}
}
上下文切换的时机
通过调用下列方法会导致自发性上下文切换:
Thread.sleep()
Object.wait()
Thread.yeild()
Thread.join()
LockSupport.park()
发生下列情况也可能导致线程上下文切换:
- 线程的时间片用完
- 有一个比当前线程优先级更高的线程需要被运行
- 虚拟机的垃圾回收动作