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