锁的五大特性
1.互斥性
锁的基本特性,当一个线程获得了锁,其他线程只能等待
2.死锁问题
使用锁就会遇到的问题,必须避免从设计和程序上避免
3.一致性
加锁和释放锁尽量是同一个线程,否则容易引发锁失效
4.可重入性
获得锁的线程,可以重复多次获得该锁
5.锁续命问题
分布式锁为避免死锁经常设置有效时间,当有效时间过期,业务还在执行时,需要通过watchdog给锁续命
并发编程三大特性
可见性、有序性、原子性
volatile 保证可见性与有序性,但是不保证原子性,保证原子性需要借助synchronized 这样的机制
指令重排序:在不影响单线程程序执行结果的前提下,计算机为了最大限度的发挥机器性能,会对机器指令重排序优化
重排序会遵循as-if-serial与happens-before原则