• 카테고리

    질문 & 답변
  • 세부 분야

    게임 프로그래밍

  • 해결 여부

    미해결

이렇게 이해한게 맞을까요 선생님?

22.10.05 22:50 작성 조회수 238

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개 짜리인 화장실을 생각하시면 이해하기 편리합니다.