14.Lock锁

Lock锁

定义:private final ReentrantLock lock = new ReentrantLock();

  • 从JDK5.0开始,Java提供了更强大的线程同步机制——通过显示定义同步锁对象来实现同步。同步锁使用Lock对象充当

  • ReentrantLock(可重入锁) 类实现了Lock,它拥有与synchronized相同的并发性和内存语义,

    在实现线程安全的控制中,比较常用的时ReentrantLock,可以显示加锁,释放锁

synchronized 与 lock 锁的对比

  • Lock是显示锁(手动开启和手动关闭,不要忘了关闭锁),synchronized是隐式锁,出了作用域自动释放
  • Lock只有代码块锁,synchronized有代码块锁和方法锁
  • 使用Lock锁,JVM将花费较少的时间来调度线程,性能更好。并且具有更好的扩展性(提供更好的子类)
  • 优先使用顺序
    • Lock -> 同步代码块(已经进入了方法体,分配了相应资源) -> 同步方法(在方法体之外)

Lock锁的实现

package com.senior;

import java.util.concurrent.locks.ReentrantLock;

// Lock锁
public class TestLock {
    public static void main(String[] args) {
        TestLock2 t1 = new TestLock2();

        new Thread(t1).start();
        new Thread(t1).start();
        new Thread(t1).start();
    }
}

class TestLock2 implements Runnable{

    int ticketNums = 10;
    // 定义lock锁
    private final ReentrantLock lock = new ReentrantLock();
    @Override
    public void run() {
        while (true){
            try {
                // 加锁
                lock.lock();
                if (ticketNums>0){
                    try {
                        Thread.sleep(1000);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    System.out.println(ticketNums--);
                }else {
                    break;
                }
            }finally {
                // 释放锁
                lock.unlock();
            }
        }
    }
}

std::shared_lock 是 C++11 中提供的一个线程安全的共享读(shared read lock)类。它用于实现共享/独占的读写模式,其中多个线程可以同时获得共享读,但只有一个线程可以获得独占写。 使用 std::shared_lock 可以实现共享读取数据的并发访问,因为多个线程可以同时持有共享,而不会互相阻塞。这在某些场景下可以提高性能。 下面是一个简单的示例代码,演示了如何使用 std::shared_lock: ```cpp #include <iostream> #include <shared_mutex> #include <thread> std::shared_mutex mutex; int sharedData = 0; void reader() { std::shared_lock<std::shared_mutex> lock(mutex); std::cout << "Reader: sharedData = " << sharedData << std::endl; } void writer() { std::unique_lock<std::shared_mutex> lock(mutex); sharedData++; std::cout << "Writer: sharedData incremented" << std::endl; } int main() { std::thread t1(reader); std::thread t2(reader); std::thread t3(writer); t1.join(); t2.join(); t3.join(); return 0; } ``` 在上面的示例中,我们创建了一个共享读写 `mutex` 和一个共享的变量 `sharedData`。`reader` 函数使用 `std::shared_lock` 来获取共享并读取 `sharedData`,而 `writer` 函数使用 `std::unique_lock` 来获取独占并增加 `sharedData` 的值。 在 `main` 函数中,我们创建了两个读线程和一个写线程。读线程使用共享进行读取操作,而写线程使用独占进行写入操作。 需要注意的是,`std::shared_lock` 是在 C++17 中引入的,如果你使用的是 C++11 或 C++14,可以使用 `boost::shared_lock` 来实现类似的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值