1. 并发简介。
1. 什么是并发?(串行)
2. 为什么并发使用?
(性能。发挥多处理器系统计算能力,使得异步代码更简单
)
3. .安全性问题?
死锁,性能。
2. 如何保障线程安全性?
同步:
1. Synchronized
2. Volatile
3. 显示锁lock
4. 原子变量
使用并发集合,并发工具类。
3. 对象的共享
1. Jvm内存模型
http://docs.oracle.com/javase/specs/jvms/se7/html/jvms-2.html#jvms-2.5
2. 可见性
3. 线程封闭
4. 只读共享(final)
使用并发集合,并发工具类。
4. 组合,委托
1. 设计模式(单例,装饰者,IO类)
2. 委托,客户端加锁机制
5. 并发容器
1. map
2. 同步工具类(闭锁,信号量,删栏)
6. 取消和关闭
1. 使用中断,Future取消
2. 使用线程池Eexecutor
7. 活跃性,性能
1. 死锁(顺序,资源)
2. 避免死锁(定时的锁,线程转储 Thread Dump)
3. Amdahl定律
4. 线程引入的开销?(上下文切换,内存同步,阻塞)
5. 减少锁的竞争(缩小范围,粒度,锁分段)
8. 测试
1. 单元测试 junit
2. 性能测试(垃圾回收,动态编译)
3. 其他测试方法(代码审查,静态分析工具,分析和监测工具)
9. 高级主题
1. Lock
2. 自定义同步工具(条件队列)
3. CAS (Compare-and-Swap)
4. 非阻塞算法(一个线程的失败或挂起不会导致其他线程也失败或挂起)
5. JMM (Java内存模型)(重排序)(Happens-Before)