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>>();
相关推荐
冉冰学姐11 小时前
SSM足球爱好者服务平台i387z(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·ssm 框架·足球爱好者服务平台
大飞记Python11 小时前
部门管理|“编辑部门”功能实现(Django5零基础Web平台)
前端·数据库·python·django
你的人类朋友12 小时前
【Node】认识multer库
前端·javascript·后端
清风66666613 小时前
基于单片机的智能收银机模拟系统设计
数据库·单片机·毕业设计·nosql·课程设计
资深低代码开发平台专家13 小时前
PostgreSQL 18 发布
数据库·postgresql
lang2015092814 小时前
Spring Boot 官方文档精解:构建与依赖管理
java·spring boot·后端
与衫14 小时前
在 VS Code 里看清你的数据流向:Gudu SQL Omni 实测体验
数据库·sql
why技术15 小时前
从18w到1600w播放量,我的一点思考。
java·前端·后端
间彧15 小时前
Redis Cluster vs Sentinel模式区别
后端