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

안녕하세요 가비지 컬렉터 동작 관련하여 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)
5828김재영2/19/20233085장기적으로는 this 구문을 안쓰는게 맞을까요? [2]
5827lee2/18/20233005파이썬 설치 오류 질문입니다 [1]
5826Syong2/14/20233596Socket 관련 Leak (OverlappedAsyncResult, OverlappedData) 관련 문의 [7]파일 다운로드1
5825박성원2/14/20233160Listview 컨트롤의 화면 전환 시 갱신 속도 [1]
5823검은콩2/13/20233759catch(Exception ex)의 line번호를 쉽게 알 수 없는지요? [7]
5822김지우2/11/20233029책을 보면서 sync, async 이해가 되지 않는 부분이 있습니다. [5]파일 다운로드2
5821검은콩2/9/20233049Async 신뢰성과 소켓데이터 [4]
5820차가워2/8/20233115다른 프로세스 실행 후 포커스 가져오기 [3]
5819취준생2/7/20233274WPF 관련 실무가 궁금합니다. [3]
5818윤길2/7/20232722ObservableCollection 에서 INotifyPropertyChanged 구현해야하나요? [2]
5817흰털너부리2/7/20232858배포 시 winform 실행 콘솔로그 보는 방법 [1]
5816흰털너부리2/6/20232672.net core json array validation 질문 드립니다. [1]
5815김재영2/6/20232799종단간 암호화에 대해 시나리오인데 타당한 시나리오일까요? [2]
5814한예지 donator2/6/20233116decompile? [9]
5813김재영2/5/20233054openssl genrsa 2048시 키 생성이 다르게 됩니다. - 파일첨부 [4]파일 다운로드1
5812김재영2/5/20233328openssl genrsa 2048시 키 생성이 다르게 됩니다. [2]
5811치르바2/3/20233162MiniDumpWriteDump API로 덤프수집을 했는데요.. [3]
5810이건우1/31/20233255윈도우서비스를 통한 웹통신관련 질문입니다 [3]
5809이상훈1/31/20233697다채널 영상 디스플레이어 개발 관련 질문입니다. [3]
5808근우1/30/20233379WPF 에서 UserControl 과 ControlTemplate 의 차이점은 무엇인가요? [6]
5807궁금맨1/28/20234537C# 10 책에 나온 예제의 결과가 제 컴에서는 좀 달라서요. 이유가 궁금합니다. [1]
5806스레드1/25/20233051총정리 - 다양한 스레드들 [초안] [1]파일 다운로드1
5805어웨이트1/25/20232875Taskcontinuewith vs Async/Await [2]파일 다운로드1
5804나이많은...1/25/20232732MS의 Dependency Injection(DI)에 AddSingleton으로 등록된 객체의 Event 등록후 사용시 앱 종료시 별도로 Event를 해지해야 하나요? [2]
5803dssc...1/24/20233001드라이브 문자를 통해서 물리 디스크 명칭을 알아내고 싶습니다. [1]
5802모바일앱1/22/20232857XAMARINE vs Android Studio [7]
1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...