Microsoft MVP성태의 닷넷 이야기
안녕하세요 가비지 컬렉터 동작 원리 중 궁금한점이 있습니다 [링크 복사], [링크+제목 복사],
조회: 4238
글쓴 사람
김민아
홈페이지
첨부 파일
 

안녕하세요 가비지 컬렉터 동작 관련하여 msdn을 읽고 있는데
msdn에 적힌 내용 중 궁금한 점 두 가지를 발췌해 보았습니다

1. 사용자가 새 프로세스를 시작하면 런타임에서는 인접한 주소 공간 영역을 이 프로세스에 예약합니다. 이 예약된 주소 공간을 관리되는 힙이라고 합니다.

2. 가비지 수집기는 애플리케이션의 루트를 검사하여 더 이상 사용되지 않는 개체를 결정합니다.
애플리케이션 루트에는 정적 필드, 스레드 스택의 지역 변수, CPU 레지스터, GC 핸들, finalize 큐가 포함됩니다.
각 루트는 관리되는 힙에 있는 개체를 참조하거나 Null로 설정됩니다.
가비지 수집기는 나머지 런타임에 이러한 루트를 요청할 수 있습니다.
가비지 수집기는 이 목록을 사용하여 루트에서 연결할 수 있는 모든 개체를 포함하는 그래프를 만듭니다.

위 1번 내용은 닷넷 어플리케이션을 실행할 때 CLR이 관리힙을 확보한다는 것으로 이해하였는데 이게 맞다면
관리힙 사이즈는 개발자가 작성한 코드를 참고하여 그에 맞게 할당되는 것인지 아니면 고정 사이즈로 할당되는 것인지 궁금하며

2번 내용은 가비지 개체를 구분하기 위하여 개체 참조가 관리되는 목록(애플리케이션 루트)을 만든다는 얘기인 것 같은데 이 목록은 비어있다가 런타임 중에 갱신되는 것인지
1번 내용처럼 관리힙 확보 시 인스턴스 변수들을 미리 구분하여 같이 만들어놓는 것인지 궁금합니다

두서없는 질문 죄송합니다 답변 주시면 정말 감사하겠습니다








[최초 등록일: ]
[최종 수정일: 1/19/2023]


비밀번호

댓글 작성자
 



2023-01-19 10시39분
1번은 "https://www.sysnet.pe.kr/2/0/12653" 글을 참고하세요. (해당 글에서 설명한 2가지 방식 모두 개발자가 작성한 코드를 참고하지 않습니다.)

2번은 루트 개체의 확인은 GC 수행 시에 합니다. 이 과정에서 가장 문제가 되는 것이 참조 개체 간의 참조를 확인하는 건데요, 이에 대한 성능을 높이기 위해 card table이 사용됩니다. 이에 대해서는 "https://www.sysnet.pe.kr/2/0/12649" 글을 참고하세요.
정성태
2023-01-20 04시59분
[김민아] 첨부해주신 링크 잘 읽어보았습니다 감사합니다
새로 도입된 DPAD 방식 이전에 Segment 단위로 관리하던 방식 관련하여
제가 이해한 부분이 맞는지 짧게 여쭤보고 싶은데
1. 어플리케이션 실행 시 기본적으로 64비트 환경 기준 256mb 관리힙을 할당한다
2. 가비지 수집기의 성능을 최적화하기 위해 이 전체 공간을 세대별로 나누어 관리한다
3. 이 관리힙 크기는 런타임에 동적으로 변경될 수 있다
4. 2세대 가비지 컬렉션이 일어나면 관리힙 전체를 검사한다

제가 잘못 이해한 부분이 있다면 정정해 주시면 정말 감사하겠습니다
[guest]
2023-01-20 06시28분
1. Workstation/Server GC 유형에 따라 다릅니다.
2. Yes
3. Segment 자체의 크기가 변하는 것은 아닙니다. 갯수가 바뀝니다.
4. Yes

참고로, 제가 소스 코드 레벨로 분석한 것은 아니므로 위의 정보를 100% 믿지는 마세요. ^^;
정성태
2023-01-21 10시58분
[김민아] 선생님 감사합니다 이전에 작성해주신 아래 두 링크 참고하여 공부가 많이 되었습니다
https://www.sysnet.pe.kr/2/0/1862#ref_list
https://www.sysnet.pe.kr/2/0/11446

얼마 안 되지만 커피값 하시라고 후원금 보내놓았습니다 항상 감사드립니다
[guest]
2023-01-22 12시53분
아니, 그렇게 딱딱한 글을 읽어주시고 기부금까지 보내시다니 ^^ 친절한 분이시군요.
정성태

1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5806스레드1/25/20233494총정리 - 다양한 스레드들 [초안] [1]파일 다운로드1
5805어웨이트1/25/20233331Taskcontinuewith vs Async/Await [2]파일 다운로드1
5804나이많은...1/25/20233198MS의 Dependency Injection(DI)에 AddSingleton으로 등록된 객체의 Event 등록후 사용시 앱 종료시 별도로 Event를 해지해야 하나요? [2]
5803dssc...1/24/20233367드라이브 문자를 통해서 물리 디스크 명칭을 알아내고 싶습니다. [1]
5802모바일앱1/22/20233331XAMARINE vs Android Studio [7]
5801블루투스1/19/20234001WPF 은행지폐계수기 개조 후 결과값 서버 전송 [2]파일 다운로드1
5800김민아1/19/20234238안녕하세요 가비지 컬렉터 동작 원리 중 궁금한점이 있습니다 [5]
5799guest1/19/20233573C# 공유폴더 내 Acess 디비 공유 [2]
5798kss1/19/20233308책 오탈인가요? [1]
5797이거비버1/19/20233388C# 공부 이후 MS 프레임워크.. 어느것을 공부해야할까요? 너무 많아서 정신이 없네요 [5]
5796guest1/19/20233100해킹 test [3]
5795동기1/18/20232936동기 스레드와 메서드와 While [2]
5794박규동1/18/20232950.net publish 할때마다 runtimeconfig 값이 바뀌는 현상 [1]
5793후후훗1/18/20233152.NET Core 에서 사용중인 함수 후킹 방법 [2]
5792Will...1/18/20233029소스코드 Log Write 기능을 리스트업 질문 [9]
5791PLC1/16/20233752C# - 실시간 5개 룸 모니터링 [15]
5790집으로 ...1/13/20233420[UI 멈춤 현상]deadlock 관련 글을 보고 혹시나 하고 문의 드립니다. [4]
5789guest1/10/20233284스레드와 Async Task [2]파일 다운로드1
5788kr11/10/20233780C# 에서 제공하는 컬렉션들의 차이점이 궁금합니다. [3]
5787stack1/10/20233555STACKOVERFLOW [1]
5786Dev ...1/9/20234508익명 클래스 말고 익명 구조체는 불가능한걸까요? [4]
5785음성인식1/8/20234036음성인식 System.Speech - 문법에 사용된 언어가 음성 인식기의 언어와 일치하지 않습니다. [2]
5784MS워드1/8/20233654MS워드에서 ctrl Z는 클립보드를 이용하나요? 아니면 참조자 이용하나요? [7]
5783구직자1/7/20233686C#개발자 구인광고와 초급개발자 [3]파일 다운로드1
5782Sqli...1/5/20233686윈도우11 노트북에서 exe(Sqlite)만들어 윈도우 7 PC에 설치 시 [5]
5781List맨1/5/20234167List.Add("newobj") 속도는 빠른 편인지요? [11]
1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...