zoukankan      html  css  js  c++  java
  • boost::mutex vs boost::recursive_mutex

    boost::mutex is not re-entrant, a thread can only lock it once, otherwise it’s dead-locked. The following code snippet demonstrates it:

    #include "boost/thread/mutex.hpp"

    #include <iostream>

    boost::mutex mtx;

    void bar(){

        boost::mutex::scoped_lock lLock(mtx);//!! dead-locked here

        std::cout << "bar" << std::endl;

    }

    void foo() {

        boost::mutex::scoped_lock lLock(mtx);

        std::cout << "foo" << std::endl;

        bar();

    }

    int _tmain(int argc, _TCHAR* argv[]){

        foo();

        return 0;

    }

    If you need re-entrant mutex, the boost::recursive_mutex is the choice. The following code snippet demonstrates it:

    #include "boost/thread/recursive_mutex.hpp"

    #include <iostream>

    boost::recursive_mutex r_mtx;

    void bar(){

        boost::recursive_mutex::scoped_lock lLock(r_mtx);//no problem for a thread to lock more than once

        std::cout << "bar" << std::endl;

    }

    void foo() {

    boost::recursive_mutex::scoped_lock lLock(r_mtx);

        std::cout << "foo" << std::endl;

        bar();

    }

    int _tmain(int argc, _TCHAR* argv[]){

        foo();

        return 0;

    }

    I also did a benchmark on my PC. For 1 locking operation, the result is approximately: boost::mutex: 0.043 micro second, boost::recursive_mutex: 0.068 micro second.

    Re-entrant mutex is the default in Java and C#. Generally speaking, if a mutex is shared by many modules/classes, it’s recommended to use boost::recursive_mutex; while if it’s only used by a single module/class and no re-entrant feature needed, it’s recommended to use boost::mutex.

  • 相关阅读:
    007_排序_多重排序
    Locust 运行模式
    Locust介绍
    Locust环境搭建及报错解决
    8-02全局变量与输出语句
    8-01变量
    7-15ALL、 ANY、SOME子查询
    7-14 EXISTS子查询
    7-13IN和NOT IN 子查询
    7-12简单子查询
  • 原文地址:https://www.cnblogs.com/weidagang2046/p/1916794.html
Copyright © 2011-2022 走看看