연산자 질문
448
작성한 질문수 2
그 인벤토리와 관련된 예시를 드실 때 (순환 x 예시)
인벤토리의 생성자와 소멸자를 호출해본 결과
k1 = nullptr 후에도 인벤토리의 소멸자가 호출이 안되더라구요
k1->inventory = new Inventory(k1) 이부분에 관련해서 분석을 진행하고 있는데
new Inventory(k1)에서 인벤토리의 ref 카운트 1 증가. (refcountable 규칙에 의해)
InventoryRef _inventory = new Inventory에서
이동 대입 연산자로 인해 레퍼런스 증가 x
메인 스레드 종료 후 k1의 소멸자가 호출되고서 멤버 변수도 초기화되는 과정에서 _inventory = nullptr 로 인해
레퍼런스 감소가 되어 소멸자가 출력되어야 하는게 정상 아닌가요? 제가 어느 부분에서 놓친건지 잘 모르겠습니다.. knight의 소멸자에 inv의 레퍼런스 카운트 값을 감소 시키니 inv의 소멸자가 출력됐는데, 어느 부분에서 레퍼런스 카운트 값이 1이 추가로 들어왔는지 못찾겠네요..
답변 1
1
k1->inventory = new Inventory(k1) 이부분에 관련해서 분석을 진행하고 있는데
new Inventory(k1)에서 인벤토리의 ref 카운트 1 증가. (refcountable 규칙에 의해)
스마트포인터 정책에 따라 다른데 우리가 만든 버전에서는
처음에 new 하면 refCount가 1이고, 이를 바로 inventory에 꽂아버리면 2개 됩니다.
즉, 처음 생성 이후 다른 스마트포인터한테 넘겨준 다음에
1개를 인위적으로 깎아줘야 합니다. (사유 : 생성)
표준 스마트 포인터는 make_shared로 할 때
스마트포인터에 들어가는 순간 1개로 refCount가 관리 됩니다.
writeLock을 잡을때 꼭 empty 상태여야하는 이유?
0
37
2
Memory Pool에서 오버플로우 질문입니다.
0
73
2
포토폴리오 및 진로 관련하여 고민입니다.
0
130
1
포토폴리오 관련 고민입니다.
0
68
1
실무에서도 alloc, 스마트포인터 등을 구현해서 쓰는지 궁금합니다.
0
89
2
성능 테스트 결과
0
109
2
게임 서버 Stateful, Stateless 진로 고민
0
133
1
WaitOnAddress와 Sleep의 차이 질문
0
84
1
궁금한거 있습니다.
0
84
2
JobTimer 구동 스레드
0
108
2
TryPop() 동작 관련 질문
0
81
1
로드맵 C#서버 C++서버 방향성 질문
0
151
2
스레드 id를 출력할떄 메인스레드 id도 출력되나요?
0
73
1
생명주기를 위한 의도적 복사
0
88
2
락프리의 실무에서 사용 질문
0
147
2
32bit threadID와 16비트 상위 WriteFlag에 대해
0
105
2
mutex와 sleep 차이점
0
120
1
실무에서는 어떠한 코드 스타일을 사용하는지 궁금합니다
0
161
2
Stomp Allocator의 Release함수에 대한 질문입니다.
0
98
1
공부법 관련해서
0
184
2
MakeShared 함수 관련
0
114
1
지금까지 서버코어에서 만든 내용에 대해 궁금한 점이 있어서 질문 드립니다.
0
145
2
운영체제관련 질문입니다
0
132
1
send하려는 데이터 크기가 크면 memcpy에서 문제가 발생할 것 같습니다.
0
120
2





