Microsoft MVP성태의 닷넷 이야기
안녕하세요 GC를 일시적으로 중단시키는 방법이 있을까요? [링크 복사], [링크+제목 복사],
조회: 13166
글쓴 사람
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)
594ygso...3/13/200714269ClickOnce를 이용하여 SmartClient를 배포할경우.. [2]
589김희택3/2/200713415리소스 추가 방법에 대한 아티클을 보던중에 질문요... [1]파일 다운로드1
588이성진2/24/200715690웹 -> 스마트클라이언트 -> 웹서비스 의 세션 공유 방법 ? [1]
583김영민2/22/200713881Vista에서 "관리자 권한으로 실행"을 통해 실행한 프로세스의 동작
584정성태2/22/200715366    답변글 [답변]: Vista에서 "관리자 권한으로 실행"을 통해 실행한 프로세스의 동작
582한귀순2/22/200713940sqlhelper 의 updatedataset
585정성태2/23/200713160    답변글 [답변]: sqlhelper 의 updatedataset [1]
579futu...2/16/200714665VS2005의 스마트 클라이언트에서 웹브라우저 예제 질문입니다. [1]
578정해봉2/16/200713886IE Embeded Assambly 방식에서 CAS 설정 방법 [1]
575박성민2/12/200714683COM에 데이터 보내기 질문입니다. [1]
571엔틱스2/7/200715376그냥... 질문은 아닙니다만... [2]
5682/6/200712613이런 오류 화면을 어떻게 찾아봐야 - 알아봐야 - 하는지요?파일 다운로드1
569정성태2/6/200714104    답변글 [답변]: 이런 오류 화면을 어떻게 찾아봐야 - 알아봐야 - 하는지요? [1]
570정성태2/6/200714016        답변글 [답변]: [답변]: 이런 오류 화면을 어떻게 찾아봐야 - 알아봐야 - 하는지요?
5732/8/200713017            답변글 [답변]: [답변]: [답변]: 이런 오류 화면을 어떻게 찾아봐야 - 알아봐야 - 하는지요? [1]파일 다운로드1
565한귀순2/5/200713575typed dataset 의 유용성
566정성태2/6/200715381    답변글 [답변]: typed dataset의 유용성 [1]
564정민영2/5/200713832혹시 이런 경우 보신적 있으신가 궁금합니다..^^; [2]
563창민이2/2/200713971Visual C++ COM Objects Returning Recordsets 사용에 대해.. [3]
562현석1/29/200713977C# 스마트응용장치에서 아이콘 움직이게하는거 질문요 ^^ [1]파일 다운로드1
559초보1/27/200715283급 질문 입니다. visual studio 자동 종료에 대한 질문입니다. [2]
558즈믄1/26/200714975.Net Framework v2.0에서 Winform의 Panel에 Excel파일 보여주기 [2]
556정재우1/26/200715059vista에서 smartclient의 System.Security.PermissionsRegistryPermission 에러 [1]
555dev....1/25/2007164402005 WebBrowser내에서 팝업 처리 문제 관련 질문입니다.
561정성태1/29/200719326    답변글 [답변]: 2005 WebBrowser 내에서 팝업 처리 문제 관련 질문입니다.
554sky1/23/200715105<급질문> interop 를 사용함에 있어 [2]
... 76  [77]  78  79  80  81  82  83  84  85  86  87  88  89  90  ...