inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[C++과 언리얼로 만드는 MMORPG 게임 개발 시리즈] Part4: 게임 서버

Reader-Writer Lock

강의를 듣던중에 궁금한점이 생겨서 질문드립니다.

226

변동건

작성한 질문수 2

0

  1. Reader-Writer Lock 구현중에 Atomic 변수를 사용하고 있는데, Atomic 변수자체가 lock이 포함되어 있어서 대규모 Read가 병렬적으로 처리되는 상황이 아니라면 일반 lock을 사용하는 것이 더 효율이 좋을 것 같습니다.



    하지만 Reader-Writer Lock이 의미가 있을 정도로 대규모 Read가 빈번하게 일어나는 경우에는 WriteLock쪽에서 기아 현상이 발생할 것 같습니다.

    그렇다면 Reader-Writer Lock은 피크 타임에 대규모 Read가 발생하는 경우에만 사용하는 건가요?

  2. (LThreadId << 16) & WRITE_THREAD_MASK 부분에서 굳이 & 연산을 추가로 하는 이유가 뭔가요?

네트워크 MMORPG windows-server

답변 2

0

Rookiss

  1. 기아현상이 일어날 정도라면 무한루프를 돌면서 계속 락을 잡아야 하는데 현실적으로 그런 일은 일어나지 않습니다. RW 락은 말 그대로 99.9999% 확률로 Read이고 아~주 가끔 Write일 때 유용한데, 운영자가 운영툴로 사냥 보너스를 추가한다거나 하는 경우가 그렇습니다.

  2. WRITE_MASK와 관련없는 부분을 0으로 밀기 위함입니다. 그러면 ReadCount가 0으로 세팅되어, CAS 비교할 때 ReadCount가 0이 아닐 시 실패하겠죠.

0

변동건

shift 연산을 할 경우에 WRITE_THREAD_MASK와 관련이 없는 부분은 자동적으로 0으로 채워지지 않나요?

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 변동건님.

아래는 질문에 대한 답변과 관련된 강의 내 유사한 질문의 답변 URL입니다.

  1. Reader-Writer Lock에 대한 이해를 돕기 위해 먼저 전반적인 개념을 간단히 설명드립니다. Reader-Writer Lock은 여러 스레드가 동시에 데이터를 읽을 수 있도록 허용하면서, 데이터가 쓰여지기 전까지는 다른 어떤 스레드도 데이터를 읽을 수 없도록 하는 형태의 락입니다. 특정 시점에 다수의 읽기 작업이 발생하는 시스템에서 효율적입니다. 그러나 대규모 Read가 빈번하게 발생하는 상황에서는 WriteLock에서 기아 현상이 발생할 수 있습니다. 이를 방지하기 위해 타임아웃/우선순위 제어 등 다양한 기법이 활용될 수 있습니다.

  2. (LThreadId << 16) & WRITE_THREAD_MASK에서 굳이 & 연산을 추가로 하는 이유는 비트 연산을 통해 특정 값을 얻기 위함입니다. 이는 주로 비트를 활용해 값을 분리하거나 조합하는 상황에서 사용됩니다. 아래 링크에서 비슷한 질문과 답변을 확인하실 수 있습니다.

관련 질문:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

Memory Pool에서 오버플로우 질문입니다.

0

63

2

포토폴리오 및 진로 관련하여 고민입니다.

0

112

1

포토폴리오 관련 고민입니다.

0

62

1

실무에서도 alloc, 스마트포인터 등을 구현해서 쓰는지 궁금합니다.

0

82

2

성능 테스트 결과

0

103

2

게임 서버 Stateful, Stateless 진로 고민

0

121

1

WaitOnAddress와 Sleep의 차이 질문

0

83

1

궁금한거 있습니다.

0

82

2

JobTimer 구동 스레드

0

107

2

TryPop() 동작 관련 질문

0

81

1

로드맵 C#서버 C++서버 방향성 질문

0

148

2

스레드 id를 출력할떄 메인스레드 id도 출력되나요?

0

73

1

생명주기를 위한 의도적 복사

0

86

2

락프리의 실무에서 사용 질문

0

139

2

32bit threadID와 16비트 상위 WriteFlag에 대해

0

101

2

mutex와 sleep 차이점

0

117

1

실무에서는 어떠한 코드 스타일을 사용하는지 궁금합니다

0

152

2

Stomp Allocator의 Release함수에 대한 질문입니다.

0

96

1

공부법 관련해서

0

183

2

MakeShared 함수 관련

0

114

1

지금까지 서버코어에서 만든 내용에 대해 궁금한 점이 있어서 질문 드립니다.

0

144

2

운영체제관련 질문입니다

0

131

1

send하려는 데이터 크기가 크면 memcpy에서 문제가 발생할 것 같습니다.

0

117

2

메모리 풀 질문있습니다.

0

124

1