What's wrong with this fix for double checked locking?

前端 未结 3 1024
难免孤独
难免孤独 2021-01-06 03:03

So I\'ve seen a lot of articles now claiming that on C++ double checked locking, commonly used to prevent multiple threads from trying to initialize a lazily created singlet

3条回答
  •  北荒
    北荒 (楼主)
    2021-01-06 04:05

    "The latter case breaks the idiom -- two threads might end up creating the singleton."

    But if I understand the code correctly, the first example, you check if instance already exists (might be executed by multiple threads at the same time), if it doesn't one thread get's to lock it and it creates the instance - only one thread can execute the creation at that time. All other threads get locked out and will wait.

    Once the instance is created and the mutex is unlocked the next waiting thread will lock mutex but it will not try to create new instance because the check will fail.

    Next time the instance variable is checked it will be set so no threads will try to create new instance.

    I'm not sure about the case where one thread is assigning new instance pointer to instance while another thread checks the same variable - but I believe it will be handled correctly in this case.

    Am I missing something here?

    Ok not sure about the reordering of operations but in this case it would be altering logic so I would not expect it to happen - but I'm no expert on this topic.

提交回复
热议问题