2024年5月10日发(作者:)

进程与线程的区别 进程的通信方式 线

程的通信方式

进程与线程的区别进程的通信方式线程的通信方式2011-03-15 01:04

进程与线程的区别:

通俗的解释

一个系统运行着很多进程,可以比喻为一条马路上有很多马车

不同的进程可以理解为不同的马车

而同一辆马车可以有很多匹马来拉--这些马就是线程

假设道路的宽度恰好可以通过一辆马车

道路可以认为是临界资源

那么马车成为分配资源的最小单位(进程)

而同一个马车被很多匹马驱动(线程)--即最小的运行单位

每辆马车马匹数=1

所以马匹数=1的时候进程和线程没有严格界限,只存在一个概念上的区分

马匹数1的时候才可以严格区分进程和线程

专业的解释:

简而言之,一个程序至少有一个进程,一个进程至少有一个线程.

线程的划分尺度小于进程,使得多线程程序的并发性高。另外,进程在执

行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序

的运行效率。

线程在执行过程中与进程还是有区别的。每个独立的线程有一个程序运行

的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在

应用程序中,由应用程序提供多个线程执行控制。

从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执行部分可

以同时执行。但操作系统并没有将多个线程看做多个独立的应用,来实现进程

的调度和管理以及资源分配。这就是进程和线程的重要区别。

进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程

是系统进行资源分配和调度的一个独立单位.

线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的

能独立运行的基本单位.线程自己基本上不拥有系统资源,只拥有一点在运行中

必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的

其他的线程共享进程所拥有的全部资源.

一个线程可以创建和撤销另一个线程;同一个进程中的多个线程之间可以

并发执行

进程和线程的主要差别在于它们是不同的操作系统资源管理方式。进程有

独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响,

而线程只是一个进程中的不同执行路径。线程有自己的堆栈和局部变量,但线

程之间没有单独的地址空间,一个线程死掉就等于整个进程死掉,所以多进程

的程序要比多线程的程序健壮,但在进程切换时,耗费资源较大,效率要差一

些。但对于一些要求同时进行并且又要共享某些变量的并发操作,只能用线程,

不能用进程。如果有兴趣深入的话,我建议你们看看《现代操作系统》或者

《操作系统的设计与实现》。对就个问题说得比较清楚。

+++

进程概念