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

进程与线程的区别[试题]

进程与线程的区别[试题]

进程与线程的区别:

通俗的解释

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

不同的进程可以理解为不同的马车而同一辆马车可以有很多匹马

来拉----这些马就是线程

假设道路的宽度恰好可以通过一辆马车道路可以认为是临界资源

那么马车成为分配资源的最小单位(进程) 而同一个马车被很多匹

马驱动(线程)----即最小的运行单位

每辆马车马匹数>=1

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

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

专业的解释:

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

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

进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而

极大地提高了程序的运行效率。

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

程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立

执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。

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

行部分可以同时执行。但操作系统并没有将多个线程看做多个独立的

应用,来实现进程的调度和管理以及资源分配。这就是进程和线程的

重要区别。

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

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

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

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

有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是

它可与同属一个进程的其他的线程共享进程所拥有的全部资源.

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

间可以并发执行

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

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

进程产生影响,而线程只是一个进程中的不同执行路径。线程有自己

的堆栈和局部变量,但线程之间没有单独的地址空间,一个线程死掉

就等于整个进程死掉,所以多进程的程序要比多线程的程序健壮,但

在进程切换时,耗费资源较大,效率要差一些。但对于一些要求同时

进行并且又要共享某些变量的并发操作,只能用线程,不能用进程。

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

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

++++++++++++++++++++++++++++++++++++++

+++++++++

进程概念

进程是表示资源分配的基本单位,又是调度运行的基本单位。例

如,用户运行自己的程序,系统就创建一个进程,并为它分配资源,

包括各种表格、内存空间、磁盘空间、I,O设备等。然后,把该进程放

人进程的就绪队列。进程调度程序选中它,为它分配CPU以及其它有

关资源,该进程才真正运行。所以,进程是系统中的并发执行的单位。

在Mac、Windows NT等采用微内核结构的操作系统中,进程的

功能发生了变化:它只是资源分配的单位,而不再是调度运行的单位。

在微内核系统中,真正调度运行的基本单位是线程。因此,实现

并发功能的单位是线程。

线程概念

线程是进程中执行运算的最小单位,亦即执行处理机调度的基本

单位。如果把进程理解为在逻辑上操作系统所完成的任务,那么线程

表示完成该任务的许多可能的子任务之一。例如,假设用户启动了一

个窗口中的数据库应用程序,操作系统就将对数据库的调用表示为一

个进程。假设用户要从数据库中产生一份工资单报表,并传到一个文

件中,这是一个子任务;在产生工资单报表的过程中,用户又可以输人

数据库查询请求,这又是一个子任务。这样,操作系统则把每一个请

求――工资单报表和新输人的数据查询表示为数据库进程中的独立的线

程。线程可以在处理器上独立调度执行,这样,在多处理器环境下就

允许几个线程各自在单独处理器上进行。操作系统提供线程就是为了

方便而有效地实现这种并发性

引入线程的好处

(1)易于调度。

(2)提高并发性。通过线程可方便有效地实现并发性。进程可创建

多个线程来

执行同一程序的不同部分。

(3)开销少。创建线程比创建进程要快,所需开销很少。。

(4)利于充分发挥多处理器的功能。通过创建多线程进程(即一个进

程可具有两个或更多个线程),每个线程在一个处理器上运行,从而实

现应用程序的并发性,使每个处理器都得到充分运行。

++++++++++++++++++++++++++++++++++++++

++++++++++

进程和线程的关系:

(1)一个线程只能属于一个进程,而一个进程可以有多个线程,但

至少有一个线程。

(2)资源分配给进程,同一进程的所有线程共享该进程的所有资源。

(3)处理机分给线程,即真正在处理机上运行的是线程。

(4)线程在执行过程中,需要协作同步。不同进程的线程间要利用

消息通信的办法实现同步。

线程是指进程内的一个执行单元,也是进程内的可调度实体.

与进程的区别:

(1)调度:线程作为调度和分配的基本单位,进程作为拥有资源的基

本单位

(2)并发性:不仅进程之间可以并发执行,同一个进程的多个线程之