何为上下文切换
在多线程的编程中,一般线程的个数都大于CPU核心的个数,但是一个Cpu核心在任意时刻只能被一个线程使用。为了让这些线程都能得到有效执行,CPU采用的策略是:为每个线程分配时间片并轮转的形式。当一个线程的时间片用完时就会重新处于就绪状态,让给其他线程使用,这个过程就属于一次上下文切换。
总的来说:当前任务在执行完CPU分配的时间片切换到另一个任务之前会先保存自己的状态,以便下次再切换回这个任务时,可以再加载这个任务的状态。任务从保存到再加载的过程就是一次上下文切换。
上下文切换通常是计算密集型的。也就是说,它需要相当可观的处理器时间,在每秒几十上百次的切换中,每次切换都需要纳秒量级的时间。所以,上下文切换对系统来说意味着消耗大量的CPU时间,事实上,可能是操作系统中时间消耗最大的操作。
ps:Linux 相比与其他操作系统(包括其他类Unix 系统)有很多的优点,其中有一项就是,其上下文切换和模式切换的时间消耗非常少。