Java多线程编程概述
Java多线程的安全问题
Java多线程同步
Java多线程间的通信
Java线程Lock
Java多线程管理
保障线程安全的设计技术
Java锁的优化及注意事项
Java多线程集合
【Java多线程】单例模式与多线程

Java多线程编程的优势与风险

Java多线程编程具有以下优势:

1、提高系统的吞吐率(Throughout). 多线程编程可以使一个进程有多个并发(concurrent,即同时进行的)的操作。

2、提高响应性(Responsiveness).Web服务器会采用一些专门的线程负责用户的请求处理,缩短了用户的等待时间。

3、充分利用多核(Multicore)处理器资源. 通过多线程可以充分的利用CPU资源。

Java多线程编程存在的问题与风险:

1、线程安全(Thread safe)问题.多线程共享数据时,如果没有采取正确的并发访问控制措施,就可能会产生数据一致性问题,如读取脏数据(过期的数据), 如丢失数据更新。

2、线程活性(thread liveness)问题.由于程序自身的缺陷或者由资源稀缺性导致线程一直处于非RUNNABLE状态,这就是线程活性问题,常见的活性故障有以下几种:

● 死锁(Deadlock). 类似鹬蚌相争

● 锁死(Lockout), 类似于睡美人故事中王子挂了

● 活锁(Livelock). 类似于小猫咬自己尾巴

● 饥饿(Starvation).类似于健壮的雏鸟总是从母鸟嘴中抢到食物

3、上下文切换(Context Switch). 处理器从执行一个线程切换到执行另外一个线程。

4、可靠性. 可能会由一个线程导致JVM意外终止,其他的线程也无法执行。