【并发设计模式】聊聊Balking是如何实现以及具体原理

前面的等待唤醒,其实是一个线程等待执行满足条件的逻辑,会一直死等,但是并不是全部的场景都需要死等。比如我们去坐车的时候,公交一直没来,那么就可以不去了。而等待唤醒是公交没来我就等他来了再去。

Guarded Suspension 模式会等待 if 条件为真,而 Balking 模式不会等待

这是二者之间本质的差别。

Balking模式是一种多个线程执行同一操作A时可以考虑的模式;说白了,就是多个人去买票,如果有人买到大家的票,剩余的人就可以不用在去买了。

如何实现

可以通过使用syn、lock、cas、对于共享变量不要求原子性的场景,可以使用volatile 等方式实现。

应用场景

在syn 从轻量级锁升级到重量级锁的时候,只有一个线程可以获取到锁。

单例模式

单例模式也是这样。

java 复制代码
    private volatile static MacComputer instance;

    /**
     * 获取一个对象
     * @return
     */
    public static MacComputer getMac () {
        if (Objects.isNull(instance)) {
            synchronized (Objects.class) {
                if (Objects.isNull(instance)) {
                    instance = new MacComputer();
                }
            }
        }
        return instance;
    }

单次初始化

在实际开发中,我们可以对于初始化的方式进行使用这种方式

java 复制代码
package com.jia.dp;

import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

/**
 * @author qxlx
 * @date 2023/12/31 5:16 PM
 */
public class BalkingTest {

    private boolean inited = false;

    //第一种方式 syn
    public synchronized void init() {
        if (!inited) {
            return;
        }

        inited = true;
        //业务逻辑
    }


    private Lock lock = new ReentrantLock();

    //第二种方式 lock
    public void init2() {
        try {
            lock.lock();
            if (!inited) {
                return;
            }

            inited = true;
            //业务逻辑
        } finally {
            lock.unlock();
        }
    }

    AtomicBoolean atomicBoolean = new AtomicBoolean(false);

    //第三种方式 cas
    public void init3() {
        if (!atomicBoolean.get()) {
            return;
        }
        atomicBoolean.compareAndSet(Boolean.FALSE, Boolean.TRUE);
        //业务逻辑
    }

}
相关推荐
7 977 分钟前
C语言基础知识--文件的顺序读写与随机读写
java·数据结构·算法
☆璇1 小时前
【数据结构】排序
c语言·开发语言·数据结构·算法·排序算法
我要成为c嘎嘎大王1 小时前
【C++】初识C++(1)
开发语言·c++
良木林1 小时前
JavaScript书写基础和基本数据类型
开发语言·前端·javascript
梁同学与Android2 小时前
Android ---【内存优化】常见的内存泄露以及解决方案
android·java·内存泄漏
武子康3 小时前
Java-71 深入浅出 RPC Dubbo 上手 父工程配置编写 附详细POM与代码
java·分布式·程序人生·spring·微服务·rpc·dubbo
艾莉丝努力练剑4 小时前
【LeetCode&数据结构】单链表的应用——反转链表问题、链表的中间节点问题详解
c语言·开发语言·数据结构·学习·算法·leetcode·链表
武子康5 小时前
Java-72 深入浅出 RPC Dubbo 上手 生产者模块详解
java·spring boot·分布式·后端·rpc·dubbo·nio
_殊途6 小时前
《Java HashMap底层原理全解析(源码+性能+面试)》
java·数据结构·算法
椰椰椰耶7 小时前
【Spring】拦截器详解
java·后端·spring