线程和进程的区别

线程和进程是计算机知识中两个非常重要的概念,下面就来分析下二者的区别和联系。

首先是定义上的辨析:

进程:是执行中的一段程序,即一旦程序被载入到内存中并准备执行,它就是一个进程。

线程:单个进程中执行每个任务就是一个线程。

区别:

1)进程是系统进行资源分配和调度的一个独立单位。

2)线程是进程中执行运算的最小单位。

3)一个线程只能属于一个进程,但是一个进程可以有多个线程。

4)线程是一种轻量级的进程,与进程相比,线程给操作系统带来的创建、维护和管理的负担要轻,意味着线程的代价或开销比较小。

5)线程没有地址空间,线程包含在进程的地址空间中。线程上下文只包含一个堆栈、一个寄存器、一个优先权,线程文本包含在它的进程的文本片段中。

6)进程拥有的所有的资源都属于线程,所有的线程都共享进程的内存和资源。同一进程中的多个线程共享代码段(代码和常量),数据段(全局变量和静态变量),扩展段(堆存储)。但是每个线程拥有自己的栈段,寄存器的内容,栈段又叫运行时段,用来存放所有局部变量和临时变量。

7)父和子进程使用进程间通信机制,同一进程的线程通过读取和写入数据到进程变量来通信。

8)进程内的任何线程都被看作是同位体,且处于相同的级别。不管是哪个线程创建了哪一个线程,进程内的任何线程都可以销毁、挂起、恢复和更改其它线程的优先权。线程也要对进程施加控制,进程中任何线程都可以通过销毁主线程来销毁进程,销毁主线程将导致该进程的销毁,对主线程的修改可能影响所有线程。

9)子进程不对任何其他子进程施加控制,进程的线程可以对同一进程的其他线程施加控制,子进程不能对父进程施加控制,进程中的所有线程都可以对主线程施加控制。

联系(相同点):

进程和线程都有ID/寄存器组、状态和优先权、信息块,创建后都可以更改自己的属性,都可与父进程共享资源、都不能直接访问其他无关进程或线程的资源。

综上所述,线程和进程在使用上各有优缺点:

线程执行开销小,但不利于资源的管理和维护;进程正相反。

同时,线程适合于SMP机器上运行,而进程则可以跨机器迁移。

注:SMP(Symmetrical Multi-Processing)即双CPU系统,实际上是对称多处理机系统中最常见的一种。

posted @ 2019-12-27 08:19  我有两个皮夹克  阅读(256)  评论(0编辑  收藏  举报