Microsoft MVP성태의 닷넷 이야기
안녕하세요 GC를 일시적으로 중단시키는 방법이 있을까요? [링크 복사], [링크+제목 복사],
조회: 13212
글쓴 사람
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)
321셈토2/18/200610849SPOOL --> EMF --> TEXTOUT [1]
320정보문2/18/200610629파일의 최대 크기2 [1]
318정보문2/18/200611772파일의 최대 크기
319정성태2/18/200611796    답변글 [답변]: 파일의 최대 크기 [1]
317narc...2/17/200610918[IE embeded SmartClient]에서 닷넷 리모팅 프록시 사용시 처음 2분간 딜레이현상이 발생합니다. [1]
322narc...2/20/200611729    답변글 [답변]: 다시한번 부탁드리겠습니다..
316이경찬2/15/200613142MSDN 매거진 정기구독 신청은 어디서 할수있나요? [1]
315정준명2/15/200616601[DxFramework Lite] 분산 트랜잭션에 참여하는 동안 오류가 발생했습니다. [2]
314이윤희2/14/200610795엑셀변환시....그림을 넣을려면. [1]
313장강현2/14/200610962SmartClient 디버그 문제 [1]
312정보문2/13/200611051방법2006 [1]
309정보문2/10/200612163edit & continue [3]
308김용국2/11/200610644스마트클라이언트 관련질문 [ Client 에서 WebPage의 JavaScript 호출방법이 있을까요? 있다고는 한것 같은데..부탁드림^^
310정성태2/11/200610145    답변글 [답변]: 스마트클라이언트 관련질문 [ Client 에서 WebPage의 JavaScript 호출방법이 있을까요? 있다고는 한것 같은데..부탁드림^^
307narc...2/10/200611873IE Embeded 스마트클라이언트는 UserControl만 가능한가요? [2]
305정보문2/10/200612007웹 컨트롤
306정성태2/10/200611681    답변글 [답변]: 웹 컨트롤
303정보문2/10/200612566회원가입성공을 기념으로 질문 한 가지 던집니다.
304정성태2/10/200610965    답변글 [답변]: 회원가입성공을 기념으로 질문 한 가지 던집니다.
302김성2/7/200612126C#이나 VB.NET 으로 만든 것을 SETUP 해서 배포하려고 하는데요.. [1]
301참깨2/3/200616377개체가 이 속성 또는 메소드를 지원하지 않습니다. [1]
300김종욱2/2/200610755안녕하세요 [2]
299꼬부기1/19/200610036스마트클라이언트 관련 질문입니다... [2]
298정말초짜1/12/200610257smart client 질문입니다. [1]
296우승우1/4/20069901스마트클라이언트에서 COM+를 이용한 데이터 가져 오기..
297정성태1/4/200611855    답변글 [답변]: 스마트클라이언트에서 COM+를 이용한 데이터 가져 오기.. [2]
... 76  77  78  79  80  81  82  83  84  85  [86]  87  88  89  90  ...