2PL-事务并发遇到的问题(一

问题1:AI给的代码

  • 大概能用可以给个参考方向,但是还是需要自己调整和识别问题的。下面是我问的部分提示语句
  • 1.2pl 的java demo 一个事务可以有多个锁
  • 2.你给的线程启动1.先请求写锁,再请求排他锁 ;排它锁那里获取你用的是while死循环
  • 3.你给的线程启动1.先请求写锁,再请求排他锁 ;排它锁那里获取你用的是while死循环 共享锁数量已经大于0了
  • 4.重新写一个完整的2pl demo
  • 5.能给个可以给多个key一步一步枷锁。测试例子需要 两个线程 至少有一个相同的key 然后顺序执行完毕的例子

问题2:是关于锁的问题

业务写多了,锁没用太多有些问题都搞迷糊了

synchronized的问题

  • 1.如果是没加限定对象则这个锁是对当前对象生效的,也就是说两个线程访问两分方法也是互斥的。
  • 2.如果加个static那个锁的对象是class
  • 3.synchronized可以有限定对象的syn(){}
  • 4.当时代码的例子给的是wait()/notify()组合的

lock的问题

  • 同一个线程的writeLock().lock()是可重入的,我用一个线程在那里测锁阻塞的问题还在纠结怎么程序跑完了,明明是要卡在那里的。
  • 还有个问题是之前我认为读锁是共享的什么时候都是可以拿到的,后来发现当有写锁操作的时候读锁也是阻塞的

单例模式不加锁会有坑的

  • 自信慢慢的用懒加载模式写了个单例模式,测试了下惊讶的发现怎么代码两次获取的增量ID居然是一个数据。单例的懒加载模式得枷锁

饿汉式

csharp 复制代码
public class Singleton {
    private static final Singleton instance = new Singleton();
    private Singleton() {}
    public static Singleton getInstance() {
        return instance;
    }
}

双重检查锁定

csharp 复制代码
public class Singleton {
    private static volatile Singleton instance;
    private Singleton() {}
    public static Singleton getInstance() {
        if (instance == null) { // 第一次检查
            synchronized (Singleton.class) {
                if (instance == null) { // 第二次检查
                    instance = new Singleton();
                }
            }
        }
        return instance;
    }
}

最后

demo还没搞好,后面搞了个简单的能跑的hello world在来分享下(大概搞下多个线程能正常打印数据,有相同资源会出现死锁的情况)。还有个部分是实际的流程我不太清楚按照平时的理解就是顺序一个一个表进行更新(没有外键级联那种)。

swift 复制代码
//大概会事下面这个样子
 // 管理每个 key 对应的读写锁 锁冲突是全局的
    private static final ConcurrentHashMap<String, ReadWriteLock> lockMap = new ConcurrentHashMap<>();
    // 每个事务对应 key锁 可以提前检擦可能的锁冲突 long是个全局的事务ID
    private static final ConcurrentHashMap<Long, List<ResourcLock>> transactionLocks = new ConcurrentHashMap<Long, List<ResourcLock>>();
相关推荐
sz-lcw3 小时前
MySQL知识笔记
笔记·mysql·adb
牛奶咖啡133 小时前
关系数据库MySQL的常用基础命令详解实战
数据库·mysql·本地远程连接到mysql·创建mysql用户和密码·修改mysql用户的密码·设置mysql密码的使用期限·设置和移除mysql用户的权限
callJJ4 小时前
从 0 开始理解 Spring 的核心思想 —— IoC 和 DI(2)
java·开发语言·后端·spring·ioc·di
ANYOLY4 小时前
Redis 面试宝典
数据库·redis·面试
鲲志说4 小时前
数据洪流时代,如何挑选一款面向未来的时序数据库?IoTDB 的答案
大数据·数据库·apache·时序数据库·iotdb
没有bug.的程序员4 小时前
MVCC(多版本并发控制):InnoDB 高并发的核心技术
java·大数据·数据库·mysql·mvcc
你的人类朋友5 小时前
JWT的组成
后端
脑花儿6 小时前
ABAP SMW0下载Excel模板并填充&&剪切板方式粘贴
java·前端·数据库
SELSL6 小时前
SQLite3的API调用实战例子
linux·数据库·c++·sqlite3·sqlite实战
洲覆6 小时前
Redis 核心数据类型:从命令、结构到实战应用
服务器·数据库·redis·缓存