Memorydoc
首页
  • 前端文章

    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • 《Git》
    • TypeScript
    • JS设计模式总结
    • HTML
    • CSS
    • 前端拓展
  • 编程之道

    • 并发编程
    • 设计模式
    • 数据结构算法
    • 技术拓展
    • 技术陷阱
    • 面试宝典
  • 分布式

    • 微服务
    • 数据库
  • 项目优化实战

    • JVM 优化
    • 线程池优化
    • 模板引擎优化
    • 任务调度优化
    • 内存优化
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
关于
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

Memorydoc

术尚可求
首页
  • 前端文章

    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • 《Git》
    • TypeScript
    • JS设计模式总结
    • HTML
    • CSS
    • 前端拓展
  • 编程之道

    • 并发编程
    • 设计模式
    • 数据结构算法
    • 技术拓展
    • 技术陷阱
    • 面试宝典
  • 分布式

    • 微服务
    • 数据库
  • 项目优化实战

    • JVM 优化
    • 线程池优化
    • 模板引擎优化
    • 任务调度优化
    • 内存优化
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
关于
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • 并发编程

    • 多线程基础
    • Atomic
    • synchronized
    • volatile(内存可见)
    • ReentrantLock
    • Lock 和 CountDownLatch
    • 线程池
    • 并发集合
    • 综合
    • 线程约束
    • 线程通信
    • 情景案例
    • AQS(AbstractQueuedSynchronizer)
    • 自己实现锁
      • CAS实现锁
      • 利用AQS实现锁
      • 测试
    • 通过lock 手写阻塞队列
    • 通过Condition 手写阻塞队列
    • 阻塞队列实现生产者消费者模式
    • StampedLock 乐观读写锁
  • 设计模式

  • 数据结构算法

  • 技术拓展

  • 技术陷阱

  • 面试宝典

  • 微服务

  • 数据库

  • 项目优化背景

  • JVM优化

  • 技术架构
  • 并发编程
Memorydoc
2022-03-07

自己实现锁原创

# CAS实现锁

/**
 * @version 1.0
 * @description: 这是一个不可重入锁,如果 重复lock会产生死锁
 * @author: Kevin
 * @create: 2019-08-27 00:16
 **/
public class SLock {
    private AtomicReference atomicReference = new AtomicReference();

    public void lock(){
        Thread currentThread = Thread.currentThread();
        //自旋
        for(;;){
            // 如果atomicReference 为null,则获取锁
            if(atomicReference.compareAndSet(null,currentThread ))return;
        }
    }
    public void unlock(){
        Thread currentThread = Thread.currentThread();
        //将 设置为null ,释放锁
        atomicReference.compareAndSet(currentThread, null);
    }
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24

# 利用AQS实现锁

AQS中使用的模板方法, 它提供了抽象方法供我们继承重写,可以实现自定义的锁机制,现在让我们利用AQS手写一把锁

package com.current.xiangxue.Lock;

import java.util.ArrayList;
import java.util.concurrent.Callable;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.locks.Lock;

/**
 * @version 1.0
 * @program: springTest
 * @description:
 * @author: Kevin
 * @create: 2019-08-27 00:19
 **/
public class Test {
    private int num = 0;

    public static void main(String[] args) {
        Test test = new Test();
        long begin = System.currentTimeMillis();
        Lock sLock = new AQSSelfLock();
        CountDownLatch countDownLatch = new CountDownLatch(100000);
        for (int i = 0; i < 100000; i++) {
            new Thread(() -> {
                // 这里两个lock会产生死锁
                //sLock.lock();
                try {
                    Thread.sleep(10);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                /*synchronized (Test.class){
                    test.num++;
                    countDownLatch.countDown();
                }*/

                try {
                    sLock.lock();
                    test.num++;
                    countDownLatch.countDown();
                } catch (Exception ex) {
                    ex.printStackTrace();
                } finally {
                    sLock.unlock();
                }


            /*    test.num++;
                countDownLatch.countDown();*/

            }).start();
        }
        try {
            long end = System.currentTimeMillis();
            long xiaohao = end - begin;
            System.out.println("消耗时间:" + xiaohao);
            countDownLatch.await();
            System.out.println(test.num);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64

# 测试

package com.current.xiangxue.Lock;

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.locks.Lock;
/**
 * @version 1.0
 * @program: springTest
 * @description:
 * @author: Kevin
 * @create: 2019-08-27 00:19
 **/
public class Test {
    private int num = 0;

    public static void main(String[] args) {
        Test test = new Test();
        long begin = System.currentTimeMillis();
        Lock sLock = new AQSSelfLock();
        CountDownLatch countDownLatch = new CountDownLatch(100000);
        for (int i = 0; i < 100000; i++) {
            new Thread(() -> {
                // 这里两个lock会产生死锁
                //sLock.lock();
                try {
                    Thread.sleep(10);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                /*synchronized (Test.class){
                    test.num++;
                    countDownLatch.countDown();
                }*/

                try {
                    sLock.lock();
                    test.num++;
                    countDownLatch.countDown();
                } catch (Exception ex) {
                    ex.printStackTrace();
                } finally {
                    sLock.unlock();
                }
            /*    test.num++;
                countDownLatch.countDown();*/

            }).start();
        }
        try {
            long end = System.currentTimeMillis();
            long xiaohao = end - begin;
            System.out.println("消耗时间:" + xiaohao);
            countDownLatch.await();
            System.out.println(test.num);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59

测试结果

不使用锁 消耗时间:9246
使用synchronized关键字 消耗时间:10751
使用利用cas实现的锁: 消耗时间:10394
使用AQS实现锁: 消耗时间:9715

编辑 (opens new window)
上次更新: 2022/03/13, 21:24:24
AQS(AbstractQueuedSynchronizer)
通过lock 手写阻塞队列

← AQS(AbstractQueuedSynchronizer) 通过lock 手写阻塞队列→

最近更新
01
命令模式 原创
05-03
02
桥接模式 原创
05-02
03
优雅写代码三 原创
04-29
更多文章>
Theme by Memorydoc | Copyright © 2021-2022 Memorydoc | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式