Microsoft MVP성태의 닷넷 이야기
안녕하세요 GC를 일시적으로 중단시키는 방법이 있을까요? [링크 복사], [링크+제목 복사],
조회: 5439
글쓴 사람
gamecsharp
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

안녕하세요. 항상 좋은 글 잘 읽고 있습니다.

C#으로 게임을 하나 만들고 있습니다. 게임에서는 GC Peak이 굉장히 큰 영향을 끼치는데요 게임 플레이 중에는 GC를 중단하고 게임이 끝나고 메뉴로 돌아오면 그 때 GC를 한번에 수행하고자 합니다.

Unity 에서는 Incremental GC 라고 해서 프레임 시간 (60Hz, 16.7ms) 내로 GC 작업을 분할하여 수행하는 좋은 기능이 있는데 .NET Core 기반으로 만든 일반 C# 프로젝트는 그런 GC 방식이 없더군요

GC.TryStartNoGCRegion 메서드를 발견하긴 했습니다만 문제는 저걸 수행하는 동안 메모리가 일정 할당을 넘어버리면 EndStartNoGCRegion을 할 때 예외가 발생해버립니다.

남은 방법이라곤 .NET Core 2.0에서 추가된 Custom GC를 통한 방법 같은데 C++ 경험이 거의 없어서 힘들군요 ㅜㅜ

물론 가장 좋은건 게임에서 할당을 자제하는 것이지만 문제는 제 로직은 할당이 적은데 기반 프레임워크가 할당이 많아서 (WPF와 Win2D를 조합하여 개발하고 있는데 WPF가 할당이 좀 많습니다) 한계가 있습니다. 성능 프로파일링을 해보면 할당의 90% 이상이 presentationframework.il 입니다.

혹시 좋은 방법이 있을까요? 감사합니다.


[연관 글]






[최초 등록일: ]
[최종 수정일: 5/23/2022]


비밀번호

댓글 작성자
 



2022-05-23 06시28분
최선의 방법이라면 GCLatencyMode.SustainedLowLatency를 쓰는 것일 듯합니다.

Latency modes
; https://docs.microsoft.com/en-us/dotnet/standard/garbage-collection/latency

Gen2 컬렉션을 시스템 메모리 부하 시(어차피 숨이 꼴딱꼴딱 넘어가는 상황에서 GC를 안 할 수도 없죠.)에만 실행하는 모드입니다.

개인적인 의견이지만, 아마도 Unity에 포함된 .NET 런타임은 .NET Core만큼 최적화되지는 않았을 것입니다. GC도 마찬가지일 텐데요, 기존의 Background GC만 해도 Stop-the-world 시간이 꽤나 줄어들 것이므로, 면밀하게 성능 테스트와 병행하시면 좋은 결과가 나오지 않을까요? ^^;
정성태
2022-05-23 11시37분
[gamecsharp] 사실 그 방법도 이미 해보았습니다. 그런데 SustainedLowLatency는 정확히는 Gen2 백그라운드 컬렉션은 그대로 하고 포그라운드 컬렉션만 시스템 메모리 부하시 안하는 거라서 효과가 있는지 잘 모르겠습니다. (여전히 Gen2는 하더군요)

그냥 LowLatency를 하면 Gen2 백그라운드도 안하지만 문제는 문서대로 Gen0과 Gen1이 엄청 빈번해져서 오히려 역효과가 발생합니다.

일단, .NET 6를 기대하는 중입니다. 현재는 .NET Core 3.1을 사용중인데 (XamlIslands 때문) .NET 6에서 성능이 크게 개선되었다고 하니 기대됩니다. (궁극적으로는 WPF에서 Windows App SDK로 옮기는 것입니다)
[guest]
2022-05-24 09시50분
그럼 TryStartNoGCRegion으로 16GB까지 확보할 수 있으니, 그걸로 한 번 해보시는 것은 어떨까요? 설마 그 이상 쓸 때까지 GC를 안 해야 한다면 답이 없군요. ^^; 참고로 EndStartNoGCRegion에서 예외가 발생하는 것은 단순히 try/catch로 처리하면 되지 않을까요?
정성태
2022-05-24 05시02분
[gamecsharp] TryStartNoGCRegion의 매개변수는 임시 세그먼트 크기를 넘을 수 없다고 되어있는데 테스를 해보니 제 PC에서는 255648868이 최대치인것 같습니다. (해당 값을 초과하면 예외가 발생합니다) 문서대로 256 MB 보다 약간 안되는 것 같은데 (워크스테이션 GC) 혹시 16 GB는 어떻게 설정하신건지 알 수 있을까요?

게임은 64비트 전용이고 제 노트북의 메모리는 32GB 입니다. 감사합니다.
[guest]
2022-05-24 07시06분
다음의 글을 참고하세요.

C# - 일정 크기를 할당하는 동안 GC를 (가능한) 멈추는 방법
; https://www.sysnet.pe.kr/2/0/13068
정성태

... 16  17  18  19  20  21  22  23  24  25  26  27  28  [29]  30  ...
NoWriterDateCnt.TitleFile(s)
5155세퉁5/7/201910421관리자 권한으로 실행 시 알림창(?) 없이 바로 실행 시킬 수 있는 방법이 있을까요?? [2]파일 다운로드1
5154Soul...5/4/20197291NamedPipe 질문드립니다. [2]
5153개태5/4/20198254WCF RESTful Service에서 enum을 parameter로 쓰는방법 [2]
5152세퉁5/3/20199373인터넷 시간을 불러와 pc에 적용 시키고 싶습니다. [3]파일 다운로드1
5151이대희5/3/20197488C# 7.3으로 개정판 출간 계획이 있으신가요? [1]
5150김이현5/2/20198866C# 딕셔너리 생성에 대해 질문드립니다. [1]
5149민성5/1/20197111ftp 이미지 업로드중 [1]
5148wpf질문4/30/20197469특정 사이트를 wpf에서 popup을 항상 허용하게 할려면 어떻게 해야할까요? [5]
5147민성4/30/20196500wpf에서 작업관리자를 띠울려면 어떻게 해야 하나요? [1]
5146불파겐4/25/20196562하나의 필드를 여러 스레드에서 읽어갈 때 스레드 동기화를 하지 않으면 문제가 생길까요? [2]
5145e구름4/17/20199509Properties.Setting.Default값에 대해 질문드립니다. [2]
5144성태님 ...4/17/20196771질문하시기 전에 10000 페이지 오류 납니다. [1]
5143헌이4/16/20197695윈도우 작업표시줄에 프로그램 띄우기 [2]파일 다운로드1
5142cab2...4/9/201913261C#으로 만든 DLL 배포하기 [10]
5141하늘사랑4/5/20198122Axinterop 래퍼에 관해서 질문드립니다. [7]
5140게스트4/1/20197767안녕하세요. 초보 개발자입니다. SD리더기에서 SD카드를 꽂으면 발생하는 이벤트 문의 [2]
5139김이현3/28/201910972C#에서 CRON 같은 스케줄러를 사용하려면 어떻게 해야 하나요? [3]
5138김지원3/22/20198617유니티 쉐이더에서 오로지 포워드 애드 패스로만 만들 수 있을까요? [1]
5137세퉁3/22/201910561wpf 쓰레드에 대해 질문 있습니다. [4]
5136KGY3/13/20197201안녕하세요 닷넷코어 콘솔 프로그램 관련 질문입니다. [1]
5135러쎌3/13/20197671ASP.NET 공부 관련해서 문의를 드립니다. [1]
5134이정호3/12/20197047SampleProfiler 예제를 이용한 Class 객체의 접근 문의 [1]파일 다운로드1
5133ㅇㅇ3/12/20197952멀티코어사용 방법에 궁금한것이 있습니다. [3]
5132존기미3/3/20198207Physical Disk Access문의 [1]
5131강용규2/25/20197301c# 개발자입니다. 타이머 질문드립니다. [1]
5130노인코래방2/25/201910865C#에서 가장 좋은 성능을 보이는 파일 읽고 쓰는 방법이 무엇인가요? [2]
... 16  17  18  19  20  21  22  23  24  25  26  27  28  [29]  30  ...