每次一提到进程和线程,自己就会有一种似懂非懂的感觉,隐约知道他们分别是什么,但好像又不能非常清楚的将他们描述,因此写这篇文章来认真的梳理一下。
抽象类比
单cpu:一台单核处理器计算机 = 一个车间;
多cpu:一台多核处理器 = 一座工厂;
进程:一个车间 = 一个进程(即一个运行的程序);
多进程:一座工厂可以同时运行多个车间;
cup和进程:单cpu只能同时运行单个进程,
多cpu可以同时运行多个进程;
线程:车间内的一个工人 = 一个线程;
进程与线程:一个进程可以包含多个线程。
线程间内存共享:每个车间的空间是该车间的所有工人门共享的。即一个进程的内存空间是共享的,同一类线程可以使用这些共享内存。
总结归纳
通过以上抽象的比喻,我们就可以清晰的知道进程与线程的区别,简单总结如下:
1.根本区别:进程是操作系统资源分配的基本单位,而进程是任务调度和执行的基本单位。
2.开销方面:每个进程都拥有独立的代码和数据空间(程序上下文),进程之间切换的开销大;线程可以看作轻量级的进程,同一类线程共享所属进程的内存资源,每个线程都有自己独立的运行栈和程序计数器,线程之间切换的开销小
3.所处环境:在操作系统中可以同时运行多个进程(程序);而同一个进程中有多个线程同时执行(通过cpu调度,在每个时间片中只有一个线程执行)
包含关系:没有线程的进程可以看做是单线程的,如果一个进程内有多个线程,则执行过程不是以条线,而是多条线(线程)共同完成的;线程是进程的一部分,线程也被称为轻量级进程。
参考文章:
进程和线程的深入理解