Android常用C++特性之std::unique_lock

声明:本文内容生成自ChatGPT,目的是为方便大家了解学习作为引用到作者的其他文章中。

std::unique_lock 是 C++ 标准库中的一种灵活的锁管理类,提供了比 std::lock_guard 更多的功能和灵活性。它可以控制对互斥锁(std::mutex)的独占所有权,并允许手动锁定、解锁、尝试锁定等操作。

std::lock_guard 不同,std::unique_lock 可以:

  • 延迟锁定:允许在构造后再锁定互斥锁。
  • 提前解锁:可以在作用域内的某个时刻手动解锁互斥锁。
  • 尝试锁定 :可以使用 try_lock() 方法尝试锁定互斥锁。

语法

cpp 复制代码
std::unique_lock<std::mutex> lock(mutex);

cpp 复制代码
std::unique_lock<std::mutex> lock(mutex, std::defer_lock); // 延迟锁定

构造函数

std::unique_lock 的构造函数有几种常用形式:

  1. 立即锁定(默认行为):

    • std::unique_lock<std::mutex> lock(mutex);
    • 创建 unique_lock 时会自动锁定传递的 mutex
  2. 延迟锁定(不锁定互斥锁):

    • std::unique_lock<std::mutex> lock(mutex, std::defer_lock);
    • 创建 unique_lock 时不会立即锁定互斥锁,你需要手动调用 lock() 来锁定。
  3. 尝试锁定(尝试立即锁定):

    • std::unique_lock<std::mutex> lock(mutex, std::try_to_lock);
    • 尝试锁定互斥锁,如果锁定失败,不会阻塞线程,可以通过 lock.owns_lock() 检查是否成功获得锁。
  4. 直接采用已有的锁定

    • std::unique_lock<std::mutex> lock(mutex, std::adopt_lock);
    • 使用此选项表明互斥锁已经被锁定,unique_lock 不会再次尝试锁定。

std::unique_lock 常用方法

  1. lock() :手动锁定互斥锁。如果在构造时选择了 std::defer_lock,你可以使用 lock() 方法来在稍后锁定互斥锁。
  2. unlock():手动解锁互斥锁。你可以在需要时释放锁以允许其他线程访问共享资源。
  3. try_lock() :尝试锁定互斥锁。如果锁定成功,返回 true,否则返回 false。该方法不会阻塞线程。
  4. owns_lock() :返回一个布尔值,表示 unique_lock 是否拥有互斥锁的所有权。
  5. release() :释放 unique_lock 对互斥锁的控制权,但不会解锁互斥锁。这在某些高级场景中可能有用。

示例

1. 基本使用
cpp 复制代码
#include <iostream>
#include <thread>
#include <mutex>

std::mutex mtx;

void printThreadId(int id) {
    std::unique_lock<std::mutex> lock(mtx);  // 自动锁定互斥锁
    std::cout << "Thread ID: " << id << std::endl;
    // lock 作用域结束后自动解锁
}

int main() {
    std::thread t1(printThreadId, 1);
    std::thread t2(printThreadId, 2);

    t1.join();
    t2.join();

    return 0;
}
2. 延迟锁定
cpp 复制代码
#include <iostream>
#include <thread>
#include <mutex>

std::mutex mtx;

void work() {
    std::unique_lock<std::mutex> lock(mtx, std::defer_lock);  // 延迟锁定
    std::cout << "Before locking." << std::endl;

    lock.lock();  // 手动锁定
    std::cout << "Lock acquired." << std::endl;

    lock.unlock();  // 手动解锁
    std::cout << "Lock released." << std::endl;
}

int main() {
    std::thread t1(work);
    std::thread t2(work);

    t1.join();
    t2.join();

    return 0;
}

在这个例子中,互斥锁在稍后通过 lock() 手动锁定,然后通过 unlock() 解锁。

3. 尝试锁定
cpp 复制代码
#include <iostream>
#include <thread>
#include <mutex>

std::mutex mtx;

void tryLockWork() {
    std::unique_lock<std::mutex> lock(mtx, std::try_to_lock);
    if (lock.owns_lock()) {
        std::cout << "Lock acquired by thread." << std::endl;
    } else {
        std::cout << "Failed to acquire lock." << std::endl;
    }
}

int main() {
    std::thread t1(tryLockWork);
    std::thread t2(tryLockWork);

    t1.join();
    t2.join();

    return 0;
}

在这个例子中,我们使用 std::try_to_lock 尝试获取锁。如果某个线程在尝试锁定时已经锁定了互斥锁,另一个线程将无法获得锁并输出"Failed to acquire lock"。

std::unique_lockstd::lock_guard 的区别

  • 灵活性std::unique_lock 提供了更多的功能(如延迟锁定、手动解锁和尝试锁定),而 std::lock_guard 则是一个更加轻量级的加锁工具,自动加锁并在作用域结束时解锁。
  • 性能std::lock_guardstd::unique_lock 更高效,因为它是针对简单的加锁/解锁场景设计的,没有额外的操作开销。如果你只需要在构造和析构时加锁和解锁,使用 std::lock_guard 更加合适。
  • 场景 :当你需要在代码的某些部分手动解锁或延迟加锁时,std::unique_lock 是更好的选择。如果你只需要简单的加锁和解锁,std::lock_guard 就足够了。

总结

  • std::unique_lock 提供了一个灵活的互斥锁管理工具,支持延迟锁定、手动解锁和尝试锁定等高级功能。
  • std::lock_guard 相比,std::unique_lock 在锁管理方面有更多的控制权,适用于更复杂的同步场景。
  • 在多线程编程中,std::unique_lock 适合那些需要在特定时刻手动锁定或解锁的场景,而 std::lock_guard 则更适合简单、固定的锁管理。
相关推荐
王老师青少年编程3 小时前
gesp(C++五级)(14)洛谷:B4071:[GESP202412 五级] 武器强化
开发语言·c++·算法·gesp·csp·信奥赛
DogDaoDao3 小时前
leetcode 面试经典 150 题:有效的括号
c++·算法·leetcode·面试··stack·有效的括号
一只小bit4 小时前
C++之初识模版
开发语言·c++
CodeClimb5 小时前
【华为OD-E卷 - 第k个排列 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
apz_end6 小时前
埃氏算法C++实现: 快速输出质数( 素数 )
开发语言·c++·算法·埃氏算法
仟濹6 小时前
【贪心算法】洛谷P1106 - 删数问题
c语言·c++·算法·贪心算法
北顾南栀倾寒7 小时前
[Qt]系统相关-网络编程-TCP、UDP、HTTP协议
开发语言·网络·c++·qt·tcp/ip·http·udp
old_power8 小时前
【PCL】Segmentation 模块—— 基于图割算法的点云分割(Min-Cut Based Segmentation)
c++·算法·计算机视觉·3d
涛ing8 小时前
21. C语言 `typedef`:类型重命名
linux·c语言·开发语言·c++·vscode·算法·visual studio
PaLu-LI9 小时前
ORB-SLAM2源码学习:Initializer.cc⑧: Initializer::CheckRT检验三角化结果
c++·人工智能·opencv·学习·ubuntu·计算机视觉