单独创建一张表存放获取锁所需的key和value,key值保持唯一,value从0开始按1递增,在代码中用私有成员变量ConcurrentHashMap存储每个key value值,初始化时每个线程的ConcurrentHashMap内容都一样,多线程执行时,先通过AtomicLong获取map中的值,然后根据value的旧值执行update,更新为新值,新值为旧值加一,更新成功返回影响行数为1的是得到锁的线程,同时更新所有线程中map中对应key的value,获取锁失败的线程需要与数据库中的value进行同步,否则会出现多线程永远获取锁失败的问题。
database锁实现
2023-08-18 08:54:22