• std::lock_guard作用域内自动上锁解锁


    std::lock_guard作用域内自动上锁解锁

    对于不同线程访问统一资源时,为了避免冲突一般都通过对目标共享变量上锁和解锁,让共享变量互斥

    • 第一种方式:一般情况可以在共享变量前后分别上锁解锁,至少需要以下三个操作
    // 定义锁
    std::mutex m_mutex;
    
    // 上锁
    m_mutex.lock();
    
    // 上锁和解锁之间为对共享变量的访问操作.....
    
    // 解锁
    m_mutex.unlock();
    
    • 第二种方式:使用std::lock_guard,在std::lock_guard对象的作用域内进行互斥量的操作,例如:
    
    #include <iostream>
    #include <mutex>
    #include <thread>
    #include <windows.h>
    
    //全局变量,两个线程都会访问
    int g_num = 0;
    //定义锁
    std::mutex m_mutex;
    
    void bar()
    {
        //函数bar()范围内,自动为互斥量上锁和解锁
        std::lock_guard<std::mutex> LockGuard(m_mutex);
    
        std::cout << "This thread id is : " << std::this_thread::get_id() << "  --  g_num : " << g_num << std::endl;
        g_num++;
    }
    
    void foo()
    {
        while (1) {
            bar();
            Sleep(1000);
        }
    }
    
    int main()
    {
        std::thread first(foo);     // thread first
        std::thread second(foo);    // thread second
    
        first.join();               // pauses until first finishes
        second.join();              // pauses until second finishes
    
        return 0;
    }
    

    std::lock_guard需要在作用域范围开头定义,也可以通过块操作限制其作用域范围,例如:

    void func()
    {
    	....
    
        {	// 范围起始
        std::lock_guard<std::mutex> LockGuard(m_mutex);
    
        }	// 范围结束
    
    	....
    }
    
  • 相关阅读:
    毕业设计预习:SM3密码杂凑算法基础学习
    毕业设计预习:maxplus2入门教程
    毕业设计预习:VHDL入门知识学习(一) VHDL程序基本结构
    网络对抗课题4.3.1 SQL注入原理与实践
    20135319zl内核模块编译报告
    20135319zl字符集报告
    20135319zl elf文件报告
    20135319zl软件破解报告
    linux内核分析综合总结
    Linux内核分析期中总结
  • 原文地址:https://www.cnblogs.com/fancyop/p/13610504.html
Copyright © 2020-2023  润新知