返回对象值时的互斥锁

7 c++ multithreading mutex pthreads

如果我理解C++编译器如何处理局部变量,那么IsShutdownInProgress()不需要任何锁定,因为shutdownInProgress静态变量将放在堆栈上.我对么?

class MyClass
{
    private:
        // Irrelevant code commented away
        static pthread_mutex_t mutex;
        static bool shutdownInProgress;
    public:
        static void ShutdownIsInProgress()
        {
            pthread_mutex_lock(mutex);
            shutdownInProgress = true;                  
            pthread_mutex_unlock(mutex);
        }

        static bool IsShutdownInProgress()
        {
            // pthread_mutex_lock(mutex);
            // pthread_mutex_unlock(mutex);
            return shutdownInProgress;
        }
}
Run Code Online (Sandbox Code Playgroud)

Mik*_*our 13

我对么?

不会.这会将其复制回来; 但读取它以使该副本不同步将导致数据竞争,具有未定义的行为.您需要在锁定互斥锁的情况下制作本地副本:

static bool IsShutdownInProgress()
{
    pthread_mutex_lock(mutex);
    bool result = shutdownInProgress;
    pthread_mutex_unlock(mutex);
    return result;
}
Run Code Online (Sandbox Code Playgroud)

或者,使用不易出错的RAII锁定类型:

static bool IsShutdownInProgress()
{
    lock_guard lock(mutex);
    return shutdownInProgress;
}
Run Code Online (Sandbox Code Playgroud)

在C++ 11中,您可能会考虑std::atomic<bool>从多个线程访问简单类型以获得更方便,也许更高效的方法.