Creating Object in a thread safety way

前端 未结 8 2251
再見小時候
再見小時候 2021-02-06 12:50

Directly from this web site, I came across the following description about creating object thread safety.

Warning: When constructing an object that will b

相关标签:
8条回答
  • 2021-02-06 13:33

    As the thread scheduler can stop execution of a thread at any time (even half-way through a high level instruction like instances.push_back(this)) and switch to executing a different thread, unexpected behaviour can happen if you don't synchronize parallel access to objects.

    Look at the code below:

    #include <vector>
    #include <thread>
    #include <memory>
    #include <iostream>
    
    struct A {
        std::vector<A*> instances;
        A() { instances.push_back(this); }
        void printSize() { std::cout << instances.size() << std::endl; }
    };
    
    int main() {
        std::unique_ptr<A> a; // Initialized to nullptr.
    
        std::thread t1([&a] { a.reset(new A()); }); // Construct new A.
        std::thread t2([&a] { a->printSize(); }); // Use A. This will fail if t1 don't happen to finish before.
    
        t1.join();
        t2.join();
    }
    

    As the access to a in main()-function is not synchronized execution will fail every once in a while.

    This happens when execution of thread t1 is halted before finishing construction of the object A and thread t2 is executed instead. This results in thread t2 trying to access a unique_ptr<A> containing a nullptr.

    0 讨论(0)
  • 2021-02-06 13:33

    You just have to make sure, that even, when one thread hasn't initialized the Object, no Thread will access it (and get a NullpointerException).

    In this case, it would happen in the constructor (I suppose), but another thread could access that very object between its add to the list and the end of the constructor.

    0 讨论(0)
提交回复
热议问题