多线程优点:
- 线程间通信更加灵活方便:全局变量以及函数传参都是共用一个虚拟地址空间,只要知道地址就能访问同一块空间
- 线程的创建和销毁成本更低:创建线程,也就是创建一个pcb,共用的数据只需要使用一个指针指向同一块就可以了,不需要系统分配资源
- 同一个进程中的线程间的调度成本更低:共享同一份资源,不需要切换页表等
多进程的优点:
- 健壮性和稳定性更高:异常以及一些系统调用直接针对整个进程生效(一个进程中的全部线程全部生效),一个进程的崩溃,不会影响到另一个进程。适用于对于主程序安全性要求更高的场景,例如shell、网络服务器
多线程的优点就是多进程的缺点,多进程的优点就是多线程的缺点
共同的优点:
- IO密集型程序:多任务并行处理- -单磁盘可以并行压缩IO等待时间/多磁盘可以实现同时处理,提高对IO的操作效率
- CPU密集型程序:程序中进行大量的数据运算处理,cpu资源足够,就可以同时处理,提高效率(通常执行流的个数是cpu核心数+1)