常见线程同步的方法及案例

线程同步是确保多个线程在访问共享资源时不会出现竞争条件的一种方法。本文主要是讲解一些常见的线程同步方法及其编写对应的代码,以下是一些常见的线程同步方法:

  1. 互斥锁(Mutex)互斥锁是一种同步原语,用于防止同时多个线程同时访问一个共享资源。当一个线程获得锁后,其他试图获取该锁的线程将被阻塞,直到第一个线程释放它为止。
  2. 信号量(Semaphore)信号量是一个非负整数或者二进制值,用于多线程编程中的同步和互斥。它可以控制对公共资源的访问次数,当没有可用资源时,请求资源的线程会被阻塞。
  3. 条件变量(Condition Variable)条件变量通常与互斥锁一起使用,以允许线程在特定条件下等待并阻塞。当条件满足时,线程可以被唤醒并继续执行。

这些线程同步方法在不同的场景中有不同的适用性。在选择合适的同步策略时,需要考虑性能、可扩展性和易用性等因素。

1.互斥锁(Mutex)

互斥锁是一种同步原语,用于防止同时多个线程同时访问一个共享资源。当一个线程获得锁后,其他试图获取该锁的线程将被阻塞,直到第一个线程释放它为止。

在 Java 中,可以使用 ReentrantLock 类实现互斥锁。以下是一个简单的示例:

java 复制代码
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

public class MutexExample {
    private final Lock lock = new ReentrantLock();
    private int counter = 0;

    public void increment() {
        lock.lock();
        try {
            counter++;
        } finally {
            lock.unlock();
        }
    }

    public int getCounter() {
        return counter;
    }
}

2.信号量(Semaphore)

信号量是一个非负整数或者二进制值,用于多线程编程中的同步和互斥。它可以控制对公共资源的访问次数,当没有可用资源时,请求资源的线程会被阻塞。

在 Java 中,可以使用 Semaphore 类实现信号量。以下是一个简单的示例:

java 复制代码
import java.util.concurrent.Semaphore;

public class SemaphoreExample {
    private final Semaphore semaphore = new Semaphore(3);
    private int counter = 0;

    public void increment() throws InterruptedException {
        semaphore.acquire();
        try {
            counter++;
        } finally {
            semaphore.release();
        }
    }

    public int getCounter() {
        return counter;
    }
}

3.条件变量(Condition Variable)

条件变量通常与互斥锁一起使用,以允许线程在特定条件下等待并阻塞。当条件满足时,线程可以被唤醒并继续执行。

在 Java 中,可以使用 ReentrantLock 类和 Condition 接口实现条件变量。以下是一个简单的示例:

java 复制代码
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;

public class ConditionVariableExample {
    private final ReentrantLock lock = new ReentrantLock();
    private final Condition condition = lock.newCondition();
    private boolean available = false;

    public void await() throws InterruptedException {
        lock.lock();
        try {
            while (!available) {
                condition.await();
            }
        } finally {
            lock.unlock();
        }
    }

    public void signal() {
        lock.lock();
        try {
            available = true;
            condition.signal();
        } finally {
            lock.unlock();
        }
    }
}

这些线程同步方法在不同的场景中有不同的适用性。在选择合适的同步策略时,需要考虑性能、可扩展性和易用性等因素。

相关推荐
dovens40 分钟前
SpringBoot集成MQTT客户端
java·spring boot·后端
❀͜͡傀儡师1 小时前
Spring Boot 集成 RocksDB 实战:打造高性能 KV 存储加速层
java·spring boot·后端·rocksdb
TeamDev1 小时前
如何在 DotNetBrowser 中使用本地 AI 模型
前端·后端·.net
Rust语言中文社区1 小时前
【Rust日报】2026-05-02 Temper - 用 Rust 编写的 Minecraft 服务器项目发布 0.1.0 版
运维·服务器·开发语言·后端·rust
陈随易2 小时前
2年没用Nodejs了,Bun很香
前端·后端·程序员
用户9416146933652 小时前
Python 实时监控 A 股行情并自动筛选强势股(REST + WebSocket 两种方案)
后端·数据分析
Java编程爱好者2 小时前
吃透 ForkJoinPool:工作窃取底层原理,一次性讲透
后端
longxibo2 小时前
【Flowable 7.2 源码深度解析与实战】
java·后端·流程图
雨辰AI2 小时前
从 MySQL 迁移至人大金仓 V9 完整改造指南|分页 / 函数 / 语法兼容全部解决
java·开发语言·数据库·后端·mysql·政务