进程和线程有什么区别
定义
进程
是具有一定独立功能的程序、它是系统进行资源分配和调度的一个独立单位,重点在系统调度和单独的单位,也就是说进程是可以独 立运行的一段程序。
线程
线程进程的一个实体,是CPU调度和分派的基本单位,他是比进程更小的能独立运行的基本单位,线程自己基本上不拥有系统资源。在运行时,只是暂用一些计数器、寄存器和栈 。
关系
-
一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程(通常说的主线程)。
-
资源分配给进程,同一进程的所有线程共享该进程的所有资源。用户进程主要段segment:stack(向低地址),heap,.rodata,data/bss,.text。一个进程,上面的5部分是主要的,必须的。线程只拥有stack(线程栈,线程栈是单个线程所独享的,2M),保存自己的函数调用过程,比如heap,.rodata,data/bss,text段都是共享的。
-
线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的办法实现同步。
-
处理机分给线程,即真正在处理机上运行的是线程。
-
线程是指进程内的一个执行单元,也是进程内的可调度实体。
区别
-
调度:线程作为调度和分配的基本单位,进程作为拥有资源的基本单位。
-
并发性:不仅进程之间可以并发执行,同一个进程的多个线程之间也可以并发执行。
-
拥有资源:进程是拥有资源的一个独立单位,线程不拥有系统资源,但可以访问隶属于进程的资源。
- 原文作者:Daryl
- 原文链接:https://siskinc.github.io/post/%E8%BF%9B%E7%A8%8B%E5%92%8C%E7%BA%BF%E7%A8%8B%E6%9C%89%E4%BB%80%E4%B9%88%E5%8C%BA%E5%88%AB/
- 版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 4.0 国际许可协议进行许可,非商业转载请注明出处(作者,原文链接),商业转载请联系作者获得授权。