首先要了解进程和线程的关系,它们的关系我用集合来表示进程是A集合,线程是b集合
A集合完全包含b,b集合完全属于A。用图来表示A是一个大的圆,b是A里面小的圆。
所以我们现在来讲一下进程和线程上下文切换的cpu花销问题,线程上下文切换它只需要保存它自己私有的寄存器数据和私有的栈数据等等就完了,而进程上下文切换要保存所有当前执行的线程私有的寄存器数据和私有的栈数据等等,此外进程有些资源也要发生切换,比如打印资源,这些临界资源是属于进程的,所以这些资源也要切换给下一个进程。
如果在进一步了解进程和线程的关系,我们来思考一下,为什么会出现线程这个东西,以前是没有线程的,只有进程,如果发生io等操作进程会等待这个资源,那么cpu会无法执行下面的指令,造成一个cpu执行浪费问题,所以程序把进程给细化开来,把进程的执行流,分给多个线程。让一部分线程获取io数据的时候,其他不需要io数据的线程也可以继续在cpu里面执行,等到那个线程获取到io数据的时候,再把它执行。