线程和进程的区别和联系:
联系:
1.两者都是多任务编程方式,都能使用计算机的多核资源
2.一个进程可以创建多个线程分支,两者之间存在包含关系
3.进程线程在系统中都有自己特有的属性,ID,代码段,栈区等资源
区别:
1.进程的创建删除消耗的计算机资源比线程要多
2.进程空间独立,数据相互不干扰,有专门的IPC,线程使用全局变量进行通信
3.进程是资源分配的基本单位,线程是处理机调度的基本单位,所有的线程共享其所属进程的所有资源
4.线程执行过程之中很容易进行协作同步,而进程需要通过消息通信进行同步与代码。
5.线程的划分尺度更小,并发性更高。
6.线程共享进程的数据的同时,有自己私有的的堆栈。
7.线程不能单独执行,但是每一个线程都有程序的入口、执行序列以及程序出口。它必须组成进程才
能被执行。
8.一个进程可以有多个线程,但是一个线程同时只能被一个进程所拥有
使用场景:
当需要创造许多并发,同时任务关联性比较强时,一般用多线程
不同的任务模块可能更多使用进程
使用进程线程需要考虑数据的处理复杂度,比如进程间通信是否方便,同步互斥是否过于复杂