多线程安全问题的应对
首先有前面的分析得出多线程的安全问题是由共享资源的修改混乱导致的。
那么我们根据这两个关键的点做出应对:
- 避开使用共享资源
- 使用没有共享资源的模型
- 避开修改
- 对共享资源只读不写
- 使用不可修改的内容
- 直接应对线程安全问题
- 原子性
- 顺序性
- 可见性
对比线程和进程
线程的优点
-
创建一个新线程的代价要比创建一个新进程小得多
-
与进程之间的切换相比,线程之间的切换需要操作系统做的工作要少很多
-
线程占用的资源要比进程少很多
-
能充分利用多处理器的可并行数量
-
在等待慢速I/O操作结束的同时,程序可执行其他的计算任务
-
计算密集型应用,为了能在多处理器系统上运行,将计算分解到多个线程中实现
-
I/O密集型应用,为了提高性能,将I/O操作重叠。线程可以同时等待不同的I/O操作。
线程和进程的区别
- 进程是系统资源分配和调度的一个独立单位,线程是程序执行的最小单位
- 进程有自己的内存地址空间,进程只独享指令流执行的必要资源,如寄存器和栈
- 由于同一进程的线程 共享内存和文件资源,可以不通过内核进行直接通信
- 线程的创建、切换和终止效率更高