线程和进程的区别
线程和进程是计算机知识中两个非常重要的概念,下面就来分析下二者的区别和联系。
首先是定义上的辨析:
进程:是执行中的一段程序,即一旦程序被载入到内存中并准备执行,它就是一个进程。
线程:单个进程中执行每个任务就是一个线程。
区别:
1)进程是系统进行资源分配和调度的一个独立单位。
2)线程是进程中执行运算的最小单位。
3)一个线程只能属于一个进程,但是一个进程可以有多个线程。
4)线程是一种轻量级的进程,与进程相比,线程给操作系统带来的创建、维护和管理的负担要轻,意味着线程的代价或开销比较小。
5)线程没有地址空间,线程包含在进程的地址空间中。线程上下文只包含一个堆栈、一个寄存器、一个优先权,线程文本包含在它的进程的文本片段中。
6)进程拥有的所有的资源都属于线程,所有的线程都共享进程的内存和资源。同一进程中的多个线程共享代码段(代码和常量),数据段(全局变量和静态变量),扩展段(堆存储)。但是每个线程拥有自己的栈段,寄存器的内容,栈段又叫运行时段,用来存放所有局部变量和临时变量。
7)父和子进程使用进程间通信机制,同一进程的线程通过读取和写入数据到进程变量来通信。
8)进程内的任何线程都被看作是同位体,且处于相同的级别。不管是哪个线程创建了哪一个线程,进程内的任何线程都可以销毁、挂起、恢复和更改其它线程的优先权。线程也要对进程施加控制,进程中任何线程都可以通过销毁主线程来销毁进程,销毁主线程将导致该进程的销毁,对主线程的修改可能影响所有线程。
9)子进程不对任何其他子进程施加控制,进程的线程可以对同一进程的其他线程施加控制,子进程不能对父进程施加控制,进程中的所有线程都可以对主线程施加控制。
联系(相同点):
进程和线程都有ID/寄存器组、状态和优先权、信息块,创建后都可以更改自己的属性,都可与父进程共享资源、都不能直接访问其他无关进程或线程的资源。
综上所述,线程和进程在使用上各有优缺点:
线程执行开销小,但不利于资源的管理和维护;进程正相反。
同时,线程适合于SMP机器上运行,而进程则可以跨机器迁移。
注:SMP(Symmetrical Multi-Processing)即双CPU系统,实际上是对称多处理机系统中最常见的一种。