I have some code like the following:
KMessageQueue::KMessageQueue()
{    
    messages = new atomic<KBuffer*>[MAX_MESSAGES];
    for (int i = 0; i < MAX_MESSAGES; i++)
        messages[i].store(nullptr);
}
Where messages is a member of KMessageQueue, defined as:
std::atomic<KBuffer*>* messages;
So each element in the messages array is atomic, and I read them from another thread. But does the array pointer itself also need to be atomic? Could another thread try to access a message after the constructor completes, only to discover that messages hasn't been assigned a value yet?
But does the array pointer itself also need to be atomic?
In general it depends on how that pointer is used by different threads. If one thread may modify it when other(s) read then yes. In your case no, you do not need it. Assuming your program is correct (otherwise answer does not make any sense) you cannot use instance of your class until it is fully constructed ie constructor finishes.
Could another thread try to access a message after the constructor completes, only to discover that messages hasn't been assigned a value yet?
It is your job to make that class inaccessible by multiple threads until it is fully initialized. After that it should be fine.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With