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

안녕하세요 가비지 컬렉터 동작 관련하여 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분
아니, 그렇게 딱딱한 글을 읽어주시고 기부금까지 보내시다니 ^^ 친절한 분이시군요.
정성태

... 31  32  [33]  34  35  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
5044엿장수8/20/20188282graphedit 에 등록되어있는 필터를 가져와서 사용하는방법을 알고싶습니다 [2]
5043hori...8/20/20187920Expression에 대한 책의 예제 관련하여 질문드립니다. [1]
5042황윤하8/20/20189630모드버스 TCP 관련 질문 [3]
5041david8/18/20189287.NET WebAPI 에서 Response 지연되는 이유 [3]
5040농상8/14/20188743정규표현식에 대해서 [3]
5039유영태8/14/201810307비동기 소켓사용후 해당 스레드가 남아있을때 처리 방법 [4]파일 다운로드1
5038이정석8/9/20188461서버파일 로컬파일 비교 [2]
5037jjh8/8/201811840c# 으로 화면캡쳐해서 동영상으로 만드는앱을 만들고싶습니다 [6]
5036볼딱지8/8/20189642C# programming 개발 관련 질문이 있습니다. [1]
5035궁금합니...8/8/201810308C# 버전 고민 어떤 책을 사야하나요? [1]
5034신동열8/8/20188732덤프 파일 분석 관련해서 문의 드려요. [1]
5033최규성8/7/201810820C# WinForm, Oracle 9i 로 프로그래밍시 ODP.NET, 배포 설정 방법 질문입니다. [6]
5032이정석8/6/201812650C# 으로 만들 dll 등록 [7]
5031J.S.8/6/20188304System.Array class의 구조에 대한 질문 [1]
5030농상8/4/20188829람다 식을 이용한 메서드 정의 확대를 공부하고 있습니다. [2]
5029Soul...8/3/20188352C# ActiveX 컨트롤 질문드립니다. [4]
5028도토리8/1/20188894혹시 회사에서 TFS 구축시 SQL-Server 라이선스 정책 아시는분 계신지요? [2]
5027농상7/31/20189690Freachable Queue의 발음을 표기하면 어떨까요? [2]
5026농상7/31/201812187소멸자의 이름에 대해서 [2]
5025김기철7/30/20189625selenium 질문좀 드릴개요 [3]
5024농상7/29/20188910패턴 매칭 when에 대해서 질문있습니다. [2]
5023농상7/28/201811897패턴매칭에 대해서 질문 있습니다. [1]
5022농상7/28/20188890튜플에 대해서 건의가 있습니다. [1]
5021농상7/27/20188370예외필터에 대해서 질문이요 [4]
5020농상7/27/201811276null 조건 연산자 예제에서 잠깐 혼동이 일어났습니다. [1]
5019농상7/26/201813593오버플로우와 언더플로우 [2]
... 31  32  [33]  34  35  36  37  38  39  40  41  42  43  44  45  ...