Microsoft MVP성태의 닷넷 이야기
Dispose 패턴 구현시 Finalize 재정의에 대한 질문드립니다. [링크 복사], [링크+제목 복사]
조회: 10063
글쓴 사람
JP (junpyo1023 at gmail.com)
홈페이지
첨부 파일
 

안녕하세요.

오래전부터 성태님의 아티클과 답변을 보며 많은 도움받고 있었는데요 늦게나마 감사 인사드립니다~

다름이 아니라 MSDN에 제시된 Dispose 패턴을 구현하여 사용중 궁금한 점이 있어 질문드립니다.
(※ https://msdn.microsoft.com/ko-kr/library/fs2xkftw(v=vs.110).aspx)

---------------------------------------------------------------------------
class BaseClass : IDisposable
{
   // Flag: Has Dispose already been called?
   bool disposed = false;
   
   // Public implementation of Dispose pattern callable by consumers.
   public void Dispose()
   {
      Dispose(true);
      GC.SuppressFinalize(this);
   }
   
   // Protected implementation of Dispose pattern.
   protected virtual void Dispose(bool disposing)
   {
      if (disposed)
         return;
      
      if (disposing) {
         // Free any other managed objects here.
         //
      }
      
      // Free any unmanaged objects here.
      //
      disposed = true;
   }

   ~BaseClass()
   {
      Dispose(false);
   }
}
---------------------------------------------------------------------------
위 패턴 사용과 관련하여 여쭤봅니다~

1. Finalizer를 재정의 하면 GC가 동작할 때 Finalize queue에 들어가서 실제 정리되는 시점이 더 늦춰질 수 있다고 알고 있는데요.
GC.SuppressFinalize를 호출함은 Finalizer를 재정의한 개체라도 Finalize queue에 들어가지 않도록 하는 처리인건가요?
아니면 큐에 들어가는건 막지 못하고 Finalize의 호출만 생략하는거라면 여전히 큐에 적재되어 정리가 지연될 수 있는 상황인건지 궁금합니다.

1-1. 1번의 상황이 맞다면 굳이 Finalize를 재구현하지 않고 명시적으로만(누락되는 개체가 없다는 전제) Dispose가 호출되도록 하는것이 성능에 더욱 유리할까요?

2. GC가 수행되어 가비지가 정리되더라도 OS에 바로 자원을 반환하지는 않는데요.
OS에게 힙을 할당받거나 반환하는 과정이 부담이라 즉시는 하지 않는것으로 알고 있습니다.
그렇더라도 메모리를 크게 점유하고 있는 상황이 좀 부담스러워 적절한(?) 시점에 바로 점유율을 낮추고 싶은데요. 가능한 방법이 있을까요?
혹시 권장하지 않으신다면 의견도 좀 여쭙고 싶습니다.

아직 GC에 대한 이해가 부족하여 질문 자체에 오류가 있을 수 있습니다ㅜㅠ

바쁘실텐데 항상 감사드리며 더운데 건강 유의하십시오!








[최초 등록일: ]
[최종 수정일: 7/6/2017]


비밀번호

댓글 작성자
 



2017-07-06 01시51분
1. 네, 맞습니다. Finalize Queue에 들어가지 않습니다. 그래서 일반 객체와 동일한 취급을 받기 때문에 GC에 영향을 주지 않습니다. (그럼, 1-1 질문도 해결된 거고.)

2. 관리 객체의 경우 GC가 관리하는 heap에 할당되는데, 이 힙의 메모리는 CLR이 나름 고군부투하며 관리하는 것으로 딱히 제어할 수 있는 부분이 없습니다. 간혹 EmptyWorkingSet 메서드를 이용해 작업 관리자에서 보이는 'working set' 메모리를 작게 보이는 식의 트릭이 공개되어 있는데 권장하지 않는 이유는 다음의 글을 참고하세요.

https://stackoverflow.com/questions/1812018/what-are-the-side-effects-of-using-emptyworkingset
정성태
2017-07-06 01시54분
[JP] 빠른 답변 감사합니다!
고민하던 부분이 명쾌해진것 같습니다^^
[guest]

1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5781List맨1/5/20233792List.Add("newobj") 속도는 빠른 편인지요? [11]
5780임세1/3/20234409C# 프로그래밍 10 책 구매한 사람입니다. 3부 자료는 어디서 다운 받을 수 있나요? [4]
5779이건우1/2/20233287안녕하십니까 루프안에서 메세지처리에 관하여 질문드립니다! [2]
5778이건우12/30/20224550안녕하세요 c#에서 dll참조 관련 질문드립니다. [4]
5777감사합니...12/29/20223558UI Thread에 Invoke 처리관련 궁금합니다. [3]
5776pdf맨12/28/20223352C# MouseUp Event + pdf [10]
5775민성12/28/20223136안녕하세요 Class 관련해서 예외처리를 하나로 받아낼수 있는 방법 [1]
5774중급12/27/20223933중급개발자란 어느 수준인지요? [4]
5773김영식12/26/20223460c# 압축파일 읽어 올 때 BinaryRead 한글 처리 문제 [1]
5772눈송이12/26/20223591Excel VSTO 는 왜 Net Core, Net 5, 6 버전을 사용하지 않나요? [2]
5771김훈12/26/20223696c# .net client application 망분리(내부망,외부망) 환경에서 의문의 외부사이트 호출 대기 [2]
5770lsh12/26/20223301클라우디움안에 있는 파일을 File.Copy 하고싶은데 코드로는 접근을 못하나요? [1]
5769울타리12/20/20223337Active Directory 2012R2 2016 또는 2019 마이그렝션 문의 드립니다. [1]
5768c++12/14/20224090Thread를 사용한 C++ DLL에 관련된 질문입니다. [6]파일 다운로드2
5767민성12/9/20223441안녕하세요 ashx로 화일을 저장하고 화일명을 리턴하는데요 [1]
5766김명훈12/9/20223589웹브라우저에서 묻지 않고 바로 다운로드 [2]
5765hong12/1/20223831Winform(.Net6) 클라이언트에서 SignalR Core 웹서버에 접속시 인증서 문제 [3]파일 다운로드1
5764요한11/30/20224036c++ 동일한 객체인지 비교 방법문의 [2]
5763고필석11/30/20223554시작하자마자 비정상 종료하는 프로세스에 대한 문제 해결 조언 요청 드립니다. [3]
5762흰털너부리11/30/20223537wpf mvvm ui update 로딩중 표시 [1]
5761민성11/29/20223438죄송하지만 한가지만 더 여쭈어 보겠습니다 [1]
5760민성11/29/20223360안녕하세요 [2]
5759문정환11/28/20223709c# socket 통신할때 빅엔디언으로 바꿔줘야 하나요? [1]
5758라떼11/28/20224905Linux 에서 winform UI 어플리케이션 실행하기 [3]
5757흰털너부리11/25/20223862asp.net core EF AddDbContext,AddDbContextFactory 차이점 알려주세요 [1]
5756흰털너부리11/25/20223435asp.net core web api에서 json 특정 property 무시하는 방법 문의 드립니다. System.Text.Json 사용중입니다. [1]
1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...