多线程编程具有以下优势:
- 提高系统的吞吐率(Throughout). 多线程编程可以使一个进程 有多个并发(concurrent,即同时进行的)的操作
- 提高响应性(Responsiveness).Web 服务器会采用一些专门的线 程负责用户的请求处理,缩短了用户的等待时间
- 充分利用多核(Multicore)处理器资源. 通过多线程可以充分的 利用 CPU 资源
多线程编程存在的问题与风险:
- 线程安全(Thread safe)问题.多线程共享数据时,如果没有采取 正确的并发访问控制措施,就可能会产生数据一致性问题,如读取脏数 据(过期的数据), 如丢失数据更新.
- 线程活性(thread liveness)问题.由于程序自身的缺陷或者由资 源稀缺性导致线程一直处于非 RUNNABLE 状态,这就是线程活性问题, 常见的活性故障有以下几种:
(1) 死锁(Deadlock). 类似鹬蚌相争.
(2) 锁死(Lockout), 类似于睡美人故事中王子挂了
(3) 活锁(Livelock). 类似于小猫咬自己尾巴
(4) 饥饿(Starvation).类似于健壮的雏鸟总是从母鸟嘴中抢到食 物. - 上下文切换(Context Switch). 处理器从执行一个线程切换到执 行另外一个线程
- 可靠性. 可能会由一个线程导致 JVM 意外终止,其他的线程也 无法执行