上下文切换(也可以称作进程切换或任务切换),它指的是 CPU 从一个进程(或线程)切换至另一个进程(或线程)。
上下文指的是某一时间点 CPU 寄存器和程序计数器的内容。
寄存器:CPU 内部的闪存,速度极快。通常用于存储计算的中间值,以此提高程序的运行速度。
程序计数器:一个专用的寄存器,用于表面指令序列中 CPU 正在执行的位置。存的值为正在执行的指令位置或是下一个将会被执行的指令的位置。具体实现依赖于系统
例子:
现有线程A-B
- 先挂起线程 A,将其在 CPU 中的状态保存在内存中。
- 在内存中检索线程 B 的上下文,并将其 CPU 寄存器恢复。
- 线程 B 执行完后,根据程序计数器中指向的位置恢复线程 A。
CPU 通过为每个线程分配时间片来实现多线程机制。
CPU 通过时间片分配算法来循环执行任务,当前任务时间片用完后会切换至下一个任务。
注意:在切换前会保存上一个任务的状态,以便下次切换回此任务时可以再加载这个任务。任务从保存再加载过程称为上下文切换。
线程并不是越多越好,因为上下文切换是计算密集型的,这也就意味着此操作需要经过大量运算,从而消耗大量 CPU 时间。想要提升多线程的性能,那么就需要从上下文切换处优化。