작성
·
197
0
bool TryPop(T& value)
{
++_popCount;
Node* oldHead = _head;
while (oldHead && _head.compare_exchange_weak(oldHead, oldHead->next) == false)
{
}
if (oldHead == nullptr)
{
--_popCount;
return false;
}
value = oldHead->data;
TryDelete(oldHead);
return true;
}
void TryDelete(Node* oldHead)
{
// 나 외에 누가 있는가?
if (_popCount == 1)
{
// 나 혼자네?
// 내 데이터는 삭제
delete oldHead;
}
else
{
}
}
_popCount == 1일 때 추가로 확인을 하지 않아도
delete oldHead를 해도 된다고 설명해주셨는데요.
코드가 TryDelete 함수 호출까지 진행됐으면
CAS를 빠져나오면서 _head = oldHead->next로 _head 값을 바꿔놓게 되고,
TryPop에 새로 진입하는 thread는 현재 thread의 oldHead가 참조하고 있는 주소값을 참조할 수 없게 된다.
이렇게 이해하면 될까요?