작성
·
311
0
실행 횟수 만번
쓰레드1->_lock.Acquire(); 얘가 먼저 실행
-> while로 반복 -> int original = Interlocked.Exchange(ref _locked, 1);
-> 여기서는 오리지날이 0이기 때문에 바로 break->number++하고(이때 lock은 1)
-> _lock을 0으로 만들어줌
쓰레드2->얘는 대기하다 어느 시점에 얘가 가져감
즉, 쓰레드 1 과 쓰레드 2가 둘이 합쳐 총 2만번을 도는데
각각 번갈아 가면서 number를 ++했다가 --했다가 반복
다만 연산을 했을 때 lock으로 잠구고 연산 후 lock을 풀어주고
다른 쓰레드가 또 lock을 잠구고 lock을 풀어주고를
2만번 반복해서 결과적으로는 한번에 하나의 연산만 진행
결과는 0
이렇게 이해했는데 이게 맞는지 모르겠습니다..
답변 1
0
[이해한 것이 맞는지]~류의 질문은 질문자 분들이 어디까지 이해한 것인지를
제가 이해하는게 더 힘들어 받고 있지 않습니다!
하지만 얼핏 읽어보니, 쓰레드1이 먼저 Acquire을 한다고 생각하시면 안 됩니다.
서로 경합하는 과정이고 동시에 실행되기 때문에
먼저 선빵을 날린 쪽은 실행하고, 다른 쪽은 대기하는 간단한 원리입니다.
Lock은 자물쇠 1개 짜리인 화장실을 생각하시면 이해하기 편리합니다.