写在前头的重点总结:
- 线程安全的程度:大部分的线程安全类都不是绝对安全而是相对安全的,需要保证这个对象单独的操作是线程安全的,在调用时不需要做额外的保障措施;但是对于一些特定顺序的连续调用,就可能需要在调用端使用额外的同步手段保证调用的正确性。
- 线程安全的实现方法: 互斥\阻塞同步(synchronized、重入锁ReentrantLock);非阻塞同步——基于冲突检测的乐观并发策略,需要操作和冲突检测这两个步骤具有原子性;无同步方案(可重入代码,即对于相同的输入参数,其返回结果是可预测且相同的;线程本地存储,例如Web服务端一个请求对应一个服务器线程,从而可以使用线程本地存储解决线程安全问题)
- 锁优化——目的是在线程之间更高效地共享数据:自适应自旋锁——不放弃处理器执行时间,等待锁;锁消除——判断变量为线程私有,从而取消加锁;锁粗化——把频繁对同个对象加锁的零碎操作纳入加锁同步的范围中,从而减少加锁次数;轻量级锁;偏向锁
详细内容:https://blog.youkuaiyun.com/coslay/article/details/49722879