线程的优点
1.发挥多核CPU强大处理能力
2.业务处理建模的简单性
通过使用线程,可以将复杂且异步的工作流进一步分解为一组简单并同步的工作流,每个工作流在一个单独的线程中运行,并在特定的同步位置进行交互。
3.异步事件的简化处理
服务端接受多个客户端socket连接请求时,如果为每个连接都分配一个线程并且使用同步IO,会降低编程的开发难度,同时现代操作系统,线程数量已得到极大提升,如:NPTL线程软件包是个专门设计用于支持数十万个线程的,大多数Linux发布版本中都包含这个软件包。
线程的风险
1.安全性问题
2.死锁(网上例子非常多)
public class LeftRightDeadlock {
private final Object left = new Object();
private final Object right = new Object();
public void leftRight() {
// 得到left锁
synchronized (left) {
// 得到right锁
synchronized (right) {
doSomething();
}
}
}
public void rightLeft() {
// 得到right锁
synchronized (right) {
// 得到left锁
synchronized (left) {
doSomethingElse();
}
}
}
}
这里有专门讲死锁,还不错:
https://www.jianshu.com/p/68c0fef7b63e
3.频繁的上下文切换带来的性能问题
多线程中,线程的挂起并运行另一个线程时就会出现上下文切换操作(Context Switch),这种操作将带来极大的开销:保存和恢复执行上下文,丢失局部性,如果频繁进行上下文切换,CPU时间更多的花在线程调度上,而不是线程运行上。