首先什么是进程?进程是具有独立功能的程序关于某个数据集合的一次运行活动,进程是CPU进行资源分配的最小单位。
什么是线程?线程可以看作进程中的一个运行的实体,是CPU进行调度的单位,可以看作是一个轻量级的进程。
他们的区别如下:
①从定义上就能看出,进程是资源分配的最小单位,线程是CPU调度的最小单位。不同进程之间是不能共享数据和资源的,因为每个进程在创建的时候会分配独立的地址空间。而线程之间是共享进程的数据的,且系统不会单独给每个线程分配独立的地址空间。
②从开销方面:进程之间的切换会有较大的开销;线程可以看做轻量级的进程,同一类线程共享代码和数据空间,每个线程都有自己独立的运行栈和程序计数器(PC),线程之间切换的开销小。但是进程的创建fork,等待wait等原语都需要大量的对于程序控制块PCB以及状态寄存器的复制操作,非常耗时;但是线程则不需要。
③从宏观上,操作系统能够对多个进程同时并发执行,但是从微观上,对于每一个CPU,只能在一个时间片上运行一个线程,所以线程是调度的基本单位。单独的一个线程其实可以看成是一个进程。
④从通信的角度:线程之间的通信较为方便,这是因为在同一进程下的线程共享全局变量、静态变量等数据。而进程之间的通信需要以通信的方式(IPC)进行,比如管道,因为他们的地址和数据独立不互通。