锁的五大特性
1.互斥性
锁的基本特性,当一个线程获得了锁,其他线程只能等待
2.死锁问题
使用锁就会遇到的问题,必须避免从设计和程序上避免
3.一致性
加锁和释放锁尽量是同一个线程,否则容易引发锁失效
4.可重入性
获得锁的线程,可以重复多次获得该锁
5.锁续命问题
分布式锁为避免死锁经常设置有效时间,当有效时间过期,业务还在执行时,需要通过watchdog给锁续命
并发编程三大特性
可见性、有序性、原子性
volatile 保证可见性与有序性,但是不保证原子性,保证原子性需要借助synchronized 这样的机制
指令重排序:在不影响单线程程序执行结果的前提下,计算机为了最大限度的发挥机器性能,会对机器指令重排序优化
重排序会遵循as-if-serial与happens-before原则
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/130215.html