uses가 0이 될 때 객체 부분이 삭제가 어떻게 일어나나요?
209
작성한 질문수 4
make shared로 shared_ptr를 만들게 되면
우리가 예제에서 만든 것처럼
우리가 포인터로 가르키는 객체가 RefCountingBlock을 상속해서
메모리에 할당 될 때 같이 된다는 이점있다고 이해했습니다
Refcount_obj2(_Type&&... Args) : Ref_count_base
를 예시를 드시며
21:11 에서 설명 해주셨습니다
만약 uses가 0이 되고 weak는 아직 1일 때
객체 부분은 구현에 따라 삭제 될 수도 있고
RefCountingBlock은 남아있게 된다고 말씀해주셨는데
RefCountingBlock을 상속해서 하나의 객체로 만들어진 상태에서
객체의 부모(countringBlock)을 남긴채로 자식(객체부분)만 메모리 해제를 할 수 있는건가요?
아니면 이게 불가능 하기 때문에 그냥 구현에 따라 다른건가요?
답변 2
0
메모리를 한 번에 할당했으면 한 번에 같이 해제하는 것이 맞지만,
다만 이미 할당된 메모리에 객체를 만들어서 생성자를 호출할 수 있으니
동일하게 소멸자를 호출하되 실제 메모리는 weak를 기다렸다 소멸시키지 않을까 싶네요.
0
destroy 코드를 보다 든 생각인데
그냥 단순히 자식부분(객체) 소멸자만 호출해주고
부모부분(CountingBlock)의 소멸자는 weak가 0이 될 때
마저 호출해주면 될거같다는 생각이 들었네요..
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





