进程与线程的区别
进程是系统资源管理的最小单位(内存管理)
线程是CPU执行调度的最小单位
线程和进程类似,都是抢占式执行
创建一个新的进程:相当于开一个新工厂,开销大,成本高
创建一个新的线程:相当于在原有的工厂里建一条生产线,开销小,成本低
线程相对于进程的优点:(线程之间占用一块物理空间)
创建/销毁开销小
切换调度开销小
占用的资源小
线程相对于进程的缺点:
健壮性降低:一个线程异常中止,会导致进程异常中止
编程/调试难度加大:线程可靠性问题,线程安全问题
线程之间可以共用的资源
虚拟地址空间
文件描述符
管道,文件等,其他线程也可以打开
线程之间不可以共用的资源
1,数据不可以共同使用
2,栈不能共同使用,存放主线程的栈
3,上下文信息
4,errno错误码(使用共同的宏,但是每个no不一样)
多线程/多进程的应用场景(并行)
1,CPU密集型
2,IO密集型
1,线程不是越多越好,达到一定数目效率就没发提升了,CPU已近全部达到上限后,此时线程数如果继续增多,非但不能提高效率,反而会降低效率(线程多了,调度开销也就更大,效率就会受到影响)
2,线程如果多了,多个线程尝试访问同一个资源,就会打架(互斥方法解决)
3,某个线程可能一直得不到执行的机会,就会线程饥饿(同步方法解决)
4,某个线程异常终止,进程就会崩溃