Microsoft MVP성태의 닷넷 이야기
안녕하세요 GC를 일시적으로 중단시키는 방법이 있을까요? [링크 복사], [링크+제목 복사],
조회: 13290
글쓴 사람
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
정성태

... 76  77  78  79  80  81  82  83  84  [85]  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
353정성태4/20/200617910    답변글 [답변]: 이번겨울방학때세도나를 여행하려구하는데요,,,
351오기4/18/200610712aspx [2]
350유지연4/17/200611466smartclient DB connection관련 질문 입니다. [2]파일 다운로드1
349선재빠4/17/200611470object tag를 2개 넣으면 IE가 죽어버리네요. [2]
347박찬용4/13/200611489COM+에 관한 질문입니다. [2]
345선재빠4/11/200612304Winform을 띄울 수 있는 방법이 있나요? [3]
344선재빠4/10/200613564ASP.NET 2.0에서는 VIEWASTEXT 이란 태그옵션을 지원하지 않는군요 [3]
343선재빠4/10/200612662아래와 같은 에러가 나네요.
341선재빠4/8/200612357테스트 페이지를 보면 프레임만 나오고 안에 내용이 나오지 않는군요 [1]
340김형태4/4/200611521파일서버 관련 질문드립니다.. (데브피아 답변에 이어) [2]
339조남정4/4/200611687post 주소 읽어오기 [1]
338장두헌4/4/200613291SDK PlatForm 다시 질문 - 데브피아의 내용 [1]
337강완모4/3/200613574Cab파일이 아닌 설치용 파일로 OCX들 설치하기... [1]
335비니3/23/200614513밑에 Smart Client에 대해서 질문했던 초보입니다.. TreeView컨트롤은 보이는데 안에 내용이 안보여요. [1]
336비니3/24/200612431    답변글 [재질문]:자꾸 죄송합니다...링크페이지로 이동을 안해요.... [1]
334비니3/23/200612130Smart Client강의 따라해보다가 xml에서 활성스키마는 <Tree>,<L> 요소는 지원하지 않는다고 나와요.ㅠㅠ [1]
332정준명3/21/200612180[자문자답] VS.NET에서 COM을 참조했는데, 강력한 서명이 없다고 사용불가네요.
333정성태3/22/200610718    답변글 [답변]: [자문자답] VS.NET에서 COM을 참조했는데, 강력한 서명이 없다고 사용불가네요. [1]
330심현철3/3/200613832[질문] VS2005에서 C#으로 개발한 DLL을 Javascript에서 접근할 수 없습니다. (ActiveX with C#) [2]
329권인성2/27/200612017스마트클라이언트(clickonce) 버전관리 [1]
327권인성2/24/200611640clickonce를 통해 설치 및 업데이트하려고 하는데요...보안때문에요..
331정성태3/12/200612709    답변글 [답변]: clickonce를 통해 설치 및 업데이트하려고 하는데요...보안때문에요..
325권인성2/23/200611223SETUP 및 배포관련 [1]
326권인성2/23/200610713    답변글 [답변]: 한가지만 더 질문할게요.... [1]
323정보문2/21/200611060메일 내용에서 한글이 깨집니다. [1]파일 다운로드1
321셈토2/18/200610856SPOOL --> EMF --> TEXTOUT [1]
... 76  77  78  79  80  81  82  83  84  [85]  86  87  88  89  90  ...