Microsoft MVP성태의 닷넷 이야기
.Net 8 에서 디버거 변경 [링크 복사], [링크+제목 복사],
조회: 2007
글쓴 사람
a
홈페이지
첨부 파일
 

안녕하세요 최근 닷넷8로 전환 후 사용중인데 디버거 관련해서 질문이 있습니다

간단하게 작성해본 아래의 코드인데요


// Net 7, 8 Release 빌드
F1();

// [StackTraceHidden] // 이때도 변화가 없습니다
// [MethodImpl(MethodImplOptions.AggressiveInlining)] // 이때도 변화가 없습니다
// [MethodImpl(MethodImplOptions.AggressiveOptimization)] // 이때는 Net 6과 동일하게 F1, F2가 디버거에서 안보입니다
void F1()
{
    F2();
}

void F2()
{
    F3();
}
 
void F3()
{
    Thread.Sleep(1000);
    Console.WriteLine("F3" + Environment.StackTrace);
}





이 코드를 릴리즈로 빌드 후 Console.WriteLine 에 중단점을 잡고 디버깅 시

Net6 에서는 메인 - F3 으로 호출 스택 이 나오고
Net7, 8 에서는 메인 - F1 - F2 - F3 으로 호출 스택이 나오고 있습니다

자주 사용하지 않는 [MethodImpl(MethodImplOptions.AggressiveOptimization)] 를 명시적으로 추가 시에는 Net 6과 같은 호출 스택이 잡히는데요
Net 7, 8 의 디버거나 릴리즈 빌드 시 변경사항에서는 이러한 내역을 확인할 수 없는데 혹시 변경된 점을 알고 계실까 하여 질문 남겨봅니다

만약 실제 생성되는 바이너리도 Net8 에서 이러한 문제가 있다면 실무에서 사용중인 Net6 프로젝트의 Net8 마이그레이션을 미뤄야 할 것 같습니다

감사합니다








[최초 등록일: ]
[최종 수정일: 2/17/2024]


비밀번호

댓글 작성자
 



2024-02-17 10시23분
Jitter가 최적화를 어떻게 할지는 개발자가 관여할 수 없는 사항입니다. 설령, 지금 .NET 6가 그렇게 동작한다고 해서 이후 (지원 종료가 올해 11월 12일이니) 패치에서도 동일하게 실행될 거라고 예측해서는 안 됩니다.

참고로, .NET 8의 경우에는 Dynamic PGO의 영향이 큽니다.

.NET 8 - Dynamic PGO를 결합한 성능 향상
; https://www.sysnet.pe.kr/2/0/13448

따라서 "SET DOTNET_TieredCompilation=0" 옵션을 설정하고 테스트하면 .NET 6처럼 나올 것입니다. 물론, 그것이 언제나 동일할 거라고도 장담할 수 없습니다. 또한, 인라인 여부 역시 Jitter 측에서 임의의 내부 기준을 가지고 판단하는 것이므로,

C# - JIT 컴파일러의 인라인 메서드 처리 유무
; https://www.sysnet.pe.kr/2/0/13064

그걸 개발자가 기대한 대로 예측하고 코딩을 해서는 안 됩니다. ("https://www.sysnet.pe.kr/2/0/12005#end")
정성태

1  2  3  4  5  6  7  8  [9]  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5730김재환10/7/20224571WPF에서 디스플레이 배율이 100%가 아닌 경우, Window의 포지션 정보가 부정확해지는 문제 [2]
5729김기헌10/2/20224216안녕하세요 선생님 뮤텍스 관련 질문 드립니다 [2]
5728김경환9/29/20224229그리드뷰관련마지막질문하나드리겠습니다선생님 [5]파일 다운로드1
5727김경환9/26/20224121c# 윈폼 tcp/ip 기반 데이터그리드뷰질문하나드리겟습니다 [3]
5726양승조 donator9/22/20224839C# dll 과 C++ 간 배열 전달. SafeArray [10]파일 다운로드1
5725김기헌9/21/20223731안녕하세요 선생님 윈폼 컨트롤 Dispose 관련 질문드립니다 [2]
5724감사합니...9/19/20223759스레드와 스레드 안전한 객체 사용관련 문의드립니다. [5]
5723드리렁9/13/20223691Pinned Object에 대해서 질문이 있습니다. [2]
5722김인태9/8/20223859대화상자에서 alt + tab 후킹 작업 [1]
5721우종9/7/20224037C++ DLL 과 C# 연동 문의 [2]
5720한예지 donator9/6/20223724학습 방법 질문 있습니다. [7]
5719김경한9/6/20224057안녕하세요 질문하나만드리겠습니다...! [10]
5718김민아9/2/20224110안녕하세요 생성자 호출 시 초기화 순서 질문드립니다 [2]
5716iili...8/26/20224332WinDbg 커널 디버깅에서의 thread freeze [2]
5715에릭8/19/20224723WMI 쿼리 결과값이 Windows Service와 Console 출력에서 상이한 이유가 있을까요? [9]파일 다운로드1
5714허니빠8/18/20224755.net6 hint path 를 프로젝트 단위로 지정할 수 있는 방법을 알고싶습니다 [8]
5713김기헌8/17/20224679안녕하세요 rgb 계산 오차가 있는데 원인을 모르겠습니다.. [3]
5712하태8/17/20224154안녕하세요 background service에서 user32dll 접근 질문 드리겠습니다.! [2]
5711하태8/16/20223673안녕하세요! 윈도우즈 해상도 관련 질문 드립니다. [1]
5710장성욱8/12/20223887c# 시리얼 통신 관련 질문 [3]
5709초보8/12/20223700WPF 커맨드 관련 질문 [2]
5708민성8/11/20223960안녕하세요 c#에서 화면의 배율 및 레이아웃을 변경할려면 어떻게 해야 할까요? [2]파일 다운로드1
5707민성8/10/20223593WPF 엣지 컨트롤에서 화면이 안보이는 현상 [2]파일 다운로드1
5706종규8/7/20226019WPF 에서 SVG 아이콘 사용 방법 문의 [2]
5705김기헌8/6/20224721안녕하세요 선생님 싱글톤 패턴 간단 질문 [2]
5704따봉이8/4/20224635EventHandler 관련 [1]
1  2  3  4  5  6  7  8  [9]  10  11  12  13  14  15  ...