C++11 std::lock_guard

一 简介

头文件<mutex>

template< class Mutex >
class lock_guard;

The class lock_guard is a mutex wrapper that provides a convenient RAII-style mechanism for owning a mutex for the duration of a scoped block.

When a lock_guard object is created, it attempts to take ownership of the mutex it is given. When control leaves the scope in which the lock_guard object was created, the lock_guard is destructed and the mutex is released.

The lock_guard class is non-copyable.

即: 类 lock_guard 是互斥封装器,为在作用域块期间占有互斥提供了一种方便的RAII风格机制。
创建lock_guard对象时,它试图接收给定互斥的所有权。控制离开创建lock_guard对象的作用域时,销毁lock_guard并释放互斥。
lock_guard 类不可复制。

二 举例

例子1

#include <thread>
#include <mutex>
#include <iostream>

int g_i = 0;
std::mutex g_i_mutex;  // 保护 g_i

void safe_increment() {
  std::lock_guard<std::mutex> lock(g_i_mutex);
  ++g_i;

  std::cout << std::this_thread::get_id() << ": " << g_i << '\n';

  // g_i_mutex 在锁离开作用域时自动释放
}

int main() {
  std::cout << "main: " << g_i << '\n';

  std::thread t1(safe_increment);
  std::thread t2(safe_increment);

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

  std::cout << "main: " << g_i << '\n';
}

结果:

例子2

#include <thread>
#include <mutex>
#include <iostream>
#include <vector>

std::mutex g_mutex;  // 保护 vc
std::vector<int> vc;

void func() {

  // std::lock_guard<std::mutex> lock(g_mutex); 注意此句

  for(int i = 0; i < 100; ++i) 
  {
    vc.emplace_back(i);
  }

 std::cout << std::this_thread::get_id()  << std::endl;

  // g_mutex 在锁离开作用域时自动释放
}

int main() {
  std::cout << "main: " << vc.size() << '\n';

  std::thread t1(func);
  std::thread t2(func);

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

  std::cout << "main: " << vc.size() << '\n';

  getchar();
  return 0;
}

若不加锁,此时由于数据竞争,运行报错

若将 func 函数第一句代码放开,则运行正确:

三 参考

std::lock_guard

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在给定的代码示例中,`std::mutex`,`std::unique_lock`和`std::lock_guard`是C++中用于实现线程同步的标准库类。它们可以用于保护共享资源,以确保在多个线程同时访问该资源时不会出现竞争条件。 `std::mutex`是一个互斥体,用于实现互斥锁。它可以在需要时锁定共享资源,并在不再需要访问时解锁它。在给定的代码示例中,`std::mutex mt`是一个互斥体对象。 `std::unique_lock`和`std::lock_guard`都是互斥锁的RAII(资源获取即初始化)封装类。它们提供了一种便捷的方式来锁定和解锁互斥锁。不同之处在于,`std::unique_lock`提供了更多的灵活性,可以在运行时选择锁定和解锁的时机,而`std::lock_guard`在构造时锁定互斥锁,在析构时解锁互斥锁。在给定的代码示例中,`std::lock_guard`和`std::unique_lock`都用于在执行特定代码块时锁定互斥锁,并在代码块结束时解锁它们。 在混用`std::mutex`,`std::unique_lock`和`std::lock_guard`时,可以根据具体的需求选择合适的组合。例如,如果您需要在代码块中灵活地锁定和解锁互斥锁,可以使用`std::unique_lock`。如果您只需要在代码块中锁定和解锁互斥锁,并且不需要灵活性,可以使用`std::lock_guard`。这些类可以根据需要混合使用,以提供更具表达力和适应性的线程同步代码。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [C++11多线程编程——lock_guard和unique_lock](https://blog.csdn.net/m0_47313541/article/details/130480617)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值