进程和线程的区别
一.最小单位方面
进程是资源分配和管理的最小单元(为什么不是线程呢?因为线程自身所带的资源是不全的,还要用进程中资源)
线程是程序执行的最小单元.
二.切换成本
进程在创建时,系统需要给它分配独立的地址空间,需要用数据表来记录它的代码段,数据段以及堆栈段.当进行线程切换时,成本比较高,需要刷新cache和tlb.
同一个进程中的线程之间共用同一个地址空间,可以通过全局变量或者静态变量来实现数据同步,在切换时成本比较低.
三.通信方面
进程通信需要专门的通信方式,比如管道通信,信号量,共享内存,套接字(socket),消息队列(比如ZMQ).
线程通信:全局变量,Message消息机制(Windows),事件类(Windows)
四.健壮性
因为有独立的地址空间,一个进程崩溃后,在保护模式下不会对其他进程产生影响
线程有自己的堆栈和局部变量,但线程之间没有独立的控件,所以一个线程出现问题,可能导致整个程序出现问题.
新战场:https://blog.csdn.net/Stephen___Qin