Microsoft MVP성태의 닷넷 이야기
Pinned Object에 대해서 질문이 있습니다. [링크 복사], [링크+제목 복사],
조회: 11041
글쓴 사람
드리렁
홈페이지
첨부 파일
 

POH 포스트에서 링크를 걸어 주셨던

https://github.com/dotnet/coreclr/blob/master/Documentation/design-docs/PinnedHeap.md


위 글에 보면 POPO(Promote Only Pinned Objects)에 대한 설명이 간단히 나오는데,
Pinned Object가 Plug 주변에 있으면 어떻게 처리한다는 것인지 잘 이해가 가지 않습니다.
Plug를 쪼개서 처리 한다는 걸까요? 어떻게 쪼개는건지도 잘 이해가 가지 않네요;

혹시 POPO와 관련해서 아시는 내용있으시면 가르침 좀 부탁 드리겠습니다.
감사합니다.








[최초 등록일: ]
[최종 수정일: 9/13/2022]


비밀번호

댓글 작성자
 



2022-09-13 07시20분
저도 그 부분은 잘 이해가 안 됩니다. 문서를 쓴 분이, "plug"라고 표현을 했지만 문맥상으로 그것을 어떻게 이해해야 좋을지 해당 글만으로는 설명이 불충분합니다.

어쨌든, pinning 개체로 인해 GC Heap 관리가 어렵고, 그 와중에 GC의 성능을 높이기 위해 "Demotion"과 "POPO"와 같은 처리를 해가며 노력했다는 것으로 가볍게 이해하시면 되겠습니다. (참고로, demotion 처리에 대해서는 "https://devblogs.microsoft.com/dotnet/internals-of-the-poh" 글에서 그나마 상황 설명을 하고 있습니다.)

결국 문제는 pinning되는 개체를 미리 알 수 없었다는 점이 근본적인 원인이며, 이를 위해 .NET 5부터 할당 시점에 pinning 여부를 알 수 있는(개발자 입장에서는 지정할 수 있는) API를 제공하며, 이런 경우 해당 개체를 SOH/LOH가 아닌 POH에 분리시켜 관리한다... 라고 전체적인 이해만 해도 되겠습니다.

혹시나, 나중에라도 알게 되면 기록으로 남기겠습니다. (또는, 질문하신 분이 먼저 알게 되시면 덧글 부탁드리겠습니다. ^^)
정성태
2022-09-13 11시44분
[드리렁] 친절히 설명해 주셔서 감사드립니다!
조금 더 찾아보도록 하겠습니다.
[guest]

NoWriterDateCnt.TitleFile(s)