当前位置:   article > 正文

论同步锁范围与数据库事务范围之间的关系_事务范围大于锁范围

事务范围大于锁范围
名词解释
  • 同步锁范围: 表示当两个以上并发线程同时访问某一段代码执行区间的时候,在加锁的代码区间内(一般需要存在共享资源的情况),同一时刻只能允许有一个线程进行访问或执行
  • 数据库事务范围: 表示单个执行数据库请求的线程,在加事务的代码区间内,必须保证数据库操作的完整性。这通常是基于业务需求的定义,因为像SQLServer,Oracle这样的数据库,本身可以根据隔离级别的设置来控制到表级甚至行级的并发控制。

范围设定
规则是 锁范围 >= 事务范围

  1. class Right {
  2. public synchronized void doSynchronized() {
  3. // init here
  4. doTransaction();
  5. // destroy here
  6. }
  7. public void doTransaction() {
  8. // CRUD operations here
  9. }
  10. }

在Right类中,执行事务操作的方法doTransaction,被带有同步锁的doSynchronized的方法所调用,也就是锁范围大于事务范围,这种方式能够保证每一个事务的操作都是线程安全的。

  1. class Wrong {
  2. public void doTransaction() {
  3. // init here
  4. doSynchronized();
  5. // destroy here
  6. }
  7. public synchronized void doSynchronized() {
  8. // CRUD ope
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/440841
推荐阅读
相关标签
  

闽ICP备14008679号