Lock、synchronized和ReadWriteLock的区别和联系
http://blog.csdn.net/qq_20641565/article/details/53208909
Java中的ReentrantLock和synchronized两种锁定机制的对比
http://blog.csdn.net/fw0124/article/details/6672522
java volitate
原子操作类AtomicInteger
硬件同步原语(Atomic Hardware Primitives)
CAS(compare and swap)先比较当前的值是否等于old,如果是,就把变量p赋值为new,返回true,否则就不改变变量的值,返回false
FAA(fetch and add)先获取变量p当前的值,然后给变量增加inc,最后返回变量p之前的值
CPU的原子性,如果CAS原语反复重试,可以调用Yield()方法或者sleep()方法,这都是thread中的方法
Java线程状态以及 sheep()、wait()、yield() 的区别
https://blog.csdn.net/qq_41701956/article/details/84861232
AtomicInteger
https://segmentfault.com/a/1190000015825207?utm_source=tag-newest
只有在并发环境中,共享资源不支持并发访问,或者并发访问共享资源会导致系统错误的情况下,才需要使用锁
可重入锁:获取了锁之后,再次获取锁,不会死锁
死锁:
1、同一把锁,加锁和解锁必须放在同一个方法中
2、避免同时持有多把锁
3、持有多把锁,加锁和解锁的顺序是相反的
4、所有的线程加锁顺序一致
读写锁