搜档网
当前位置:搜档网 › 进程和线程的联系与区别

进程和线程的联系与区别

进程和线程的联系和区别


定义:
一、进程就是正在运行的程序,是系统进行资源分配和调度的一个独立单位。
二、线程是进程的一个实体,是CPU调度和分派的基本单位,他是比进程更小的能独立运行的基本单位,
新的执行线程将拥有自己的栈(也就是有自己的局部变量),但与它的创建者共享全局变量、文件描述符、信号处理函数和当前目录状态,
一个线程可以创建和撤销另一个线程;


进程和线程的关系:
(1)一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。
(2)资源分配给进程,同一进程的所有线程共享该进程的所有资源。
(3)线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的办法实现同步。
(4)处理机分给线程,即真正在处理机上运行的是线程。
(5)线程是指进程内的一个执行单元,也是进程内的可调度实体。
线程与进程的区别:
(1)调度:线程作为调度和分配的基本单位,进程作为拥有资源的基本单位。
(2)并发性:不仅进程之间可以并发执行,同一个进程的多个线程之间也可以并发执行。
(3)拥有资源:进程是拥有资源的一个独立单位,线程不拥有系统资源,但可以访问隶属于进程的资源。
(4)系统开销:在创建或撤销进程的时候,由于系统都要为之分配和回收资源,导致系统的明显大于创建或撤销线程时的开销。但进程有独立的地址空间,进程崩溃后,在保护模式下不会对其他的进程产生影响,而线程只是一个进程中的不同的执行路径。线程有自己的堆栈和局部变量,但线程之间没有单独的地址空间,一个线程死掉就等于整个进程死掉,所以多进程的程序要比多线程的程序健壮,但是在进程切换时,耗费的资源较大,效率要差些。


区别:
1.进程可以独立运行,而线程不行,它必须依附于进程
2.进程拥有独立的内存单元,而线程是共享进程的内存单元(从而极大的提高了程序运行效率)
3.相对来说,线程占用的CPU和内存比进程小(使得多线程程序的并发性高)



何时使用多线程?
1 改善用户体验,将用户界面线程与工作线程分开,比如弹出一个进度条来显示处理的进度;
2 网络通信,服务端要同时处理很多请求的时候
3 执行时间需要很长的程序,放到后台去处理
4 充分利用CPU,对于计算密集型的软件,采用多线程并行方式可以充分发挥多颗多核CPU的威力,大大提高速度。 (第4种情况下,根据需要也可以选用多进程方式代替)

总结:
1.多线程在资源消耗和通信方面比多进程有优势
2.在稳定性、数据相互影响(特别要小心全局

变量)方面,多进程则更好一些







相关主题