inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

Reader-Writer Lock

WriteUnlock을 잘 못 호출하는 경우에 대해서

해결된 질문

207

맞수

작성한 질문수 6

0

일반 Lock을 쓸 때 Unlock을 한번 더 호출해버리는 실수는 크래시가 뜨기에, 디버깅으로 알아채기 쉬운 부분이라고 생각합니다.

 

void Lock::WriteUnlock()
{
	if ((_lockFlag.load() & READ_COUNT_MASK) != 0) // Thread id를 체크하지 않음. Read가 없는 상황에서 WriteUnlock()이 통과할 수 있음.
		CRASH("INVALID_UNLOCK_ORDER");

	const int32 lockCount = --_writerCount;
	if (lockCount == 0)
		_lockFlag.store(EMPTY_FLAG);
}

하지만, WriteUnLock() 에서는 아래와 같은 경우에 문제가 있을 수 있다고 생각합니다.

 

// 실수로 호출
WriteUnlock(); // _writerCount = -1
// 크래시 없이 작업 진행
WriteLock(); // _writerCount = 0, 스레드 id 등록
WriteLock(); // _writerCount = 1
WriteUnlock(); // _writerCount = 0, 스레드 id 해제
WriteUnlock(); // _writerCount = -1

/*****
오랜 작업 뒤
******/

WriteLock(); // _writerCount = 0, 스레드 id 등록
WriteUnlock(); // _writerCount = -1
// 타 스레드 접근
ReadLock(); /*or*/ WriteLock(); // 틱 시간 초과로 CRASH

의 드문 경우에 한해서 수많은 코드 작업이 이뤄진 뒤라, 어디서 실수가 발생했는지 디버깅이 어려워질 것 같습니다.

크게 신경 쓰지 않아도 되는 건지, 아니면 놓치고 있는 부분이 있는 것인지 궁굼합니다.

네트워크 MMORPG windows-server

답변 1

1

Rookiss

어차피 직접 LOCK/UNLOCK을 하는 일은 드물고,
WRAPPER를 사용해서 자동 해제해서 사실 크게 신경쓰지 않으셔도 됩니다.

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

0

61

2

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

0

107

1

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

0

58

1

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

0

80

2

성능 테스트 결과

0

101

2

게임 서버 Stateful, Stateless 진로 고민

0

117

1

WaitOnAddress와 Sleep의 차이 질문

0

80

1

궁금한거 있습니다.

0

79

2

JobTimer 구동 스레드

0

105

2

TryPop() 동작 관련 질문

0

79

1

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

0

144

2

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

0

71

1

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

0

83

2

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

0

137

2

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

0

99

2

mutex와 sleep 차이점

0

115

1

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

0

150

2

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

0

93

1

공부법 관련해서

0

181

2

MakeShared 함수 관련

0

112

1

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

0

142

2

운영체제관련 질문입니다

0

128

1

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

0

115

2

메모리 풀 질문있습니다.

0

121

1