技术文摘
悲观锁与乐观锁的定义
悲观锁与乐观锁的定义
在软件开发中,多线程并发访问共享资源时可能会引发数据不一致等问题,而悲观锁与乐观锁是两种重要的并发控制机制,用于确保数据的完整性和一致性。
悲观锁,从名字就能看出它秉持一种悲观的态度。它认为在数据处理过程中,很可能会有其他线程同时对同一资源进行修改操作。在对共享资源进行读写操作前,悲观锁会先获取锁,将资源锁定。只有持有锁的线程才能对资源进行操作,其他线程则必须等待锁被释放。这种方式就像一个严格的管理员,只要有人要使用某个重要物品,就立刻将其独占,其他人只能排队等候。传统数据库中的行锁、表锁等都属于悲观锁的范畴。在银行转账操作中,当一个线程要修改账户余额时,悲观锁会锁定该账户记录,防止其他线程同时修改,保证了数据的准确性。不过,由于频繁的加锁和解锁操作,悲观锁在高并发场景下可能会导致性能瓶颈,因为大量线程等待锁会增加系统的开销。
乐观锁则持有乐观的看法。它假设在大多数情况下,各个线程对共享资源的操作不会发生冲突。所以,乐观锁并不会在操作前主动加锁。而是在数据提交更新时,检查在自己读取数据后到准备更新数据的这段时间内,数据有没有被其他线程修改过。这就好比大家都可以随意读取一个文件,但在保存修改时,系统会检查文件在读取后有没有被别人改过。如果没有,则允许更新;若有修改,更新操作会失败,线程需要重新读取数据并再次尝试更新。乐观锁通常通过版本号机制或时间戳来实现。在电商系统中,商品库存的修改可以使用乐观锁,多个用户读取库存时无需加锁,只有在实际扣减库存时才检查版本号,提高了系统的并发性能。但乐观锁也有局限性,在冲突频繁的场景下,可能导致大量的重试操作,降低系统效率。
悲观锁和乐观锁各有优缺点,在实际开发中,需要根据具体的业务场景和并发需求来合理选择使用,以实现高效、稳定的系统运行。
- ChatGPT 爆火霸榜 Github ,其周边实用性超强!
- Go 版本大于 1.13 时 程序中的地道错误处理方法
- 基于 Vite 快速搭建 Vue3+ts+pinia 脚手架
- Canvas 性能优化之脏矩形渲染
- Elasticsearch 中的 Global、Filters 与 Cardinality 聚合
- 从 PHP 转 Go 框架如何选?
- 前端工程师视角下的设计模式:适配器模式
- 硅谷大厂裁员潮中职场新人:于小厂继续卷
- 罕见的符号编程论文:在 Jupyter Notebook 中实现手绘草图转代码
- CSS 羽化效果的实现方法
- Spring Boot 中定义接口的方法能否声明为 private ?
- Vue 3 高颜值 UI 组件库的 12 个盘点
- 图像数据的特征处理
- Vue3 必知的七个技巧
- 共探分布式架构的可观测性,你知多少?