Microsoft MVP성태의 닷넷 이야기
.Net 8 에서 디버거 변경 [링크 복사], [링크+제목 복사],
조회: 1993
글쓴 사람
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")
정성태

... 16  17  18  19  20  21  22  23  24  25  [26]  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5257C#초보11/9/20197440파일 저장 방법에 대해 조언 부탁드립니다. [3]
5256세퉁11/8/20196759안녕하세요~ 질문은 아닙니다만.. [1]
5255C#초보11/6/20197317중첩 딕셔너리를 어떻게 만들 수 있을까요? [2]
5252김동수11/4/20196930Windows 10 로그인 ( Credential Provider ) 문의드립니다. [1]
5251kss11/1/20197009c#문법질문입니다. [1]
5250이대희10/31/20197116시작하세요 C# 7.3 프로그래밍 책이 절판이네요. [1]
5249황태관10/24/20197595c# 폼안에 특정 프로그램 불러오기.. [1]파일 다운로드1
5248황태관10/23/20198439C언어로 만든 dll 를 참조해서 c#으로 만들려면.. [3]
5245민성10/21/20197531안녕하세요 Ui 스레드 접근에 대해서 질문드리도록 하겠습니다. [1]
5244hbli...10/20/20196973두개의 쓰레드에서 하나의 Queue 리스트 사용시 질문드립니다. [2]
5243최선호 donator10/18/20196561Screen Capture 와.. Overlay 질문 좀 드릴게요 ㅠ.ㅠ ( 장문 주의..... ) [2]
5241C#초보10/16/20198571C# USB 통신 구현 관련 질문 드립니다! [1]
5240김동규10/15/20198507런타임 시 Encoding.Default를 UTF-8로 설정할 수 있을까요? [3]
5239밤톨이10/13/20196755시놀리지 DSM에 asp.net core 2 웹서버 구축이 가능한가요? [1]
5238권석헌10/2/20197301C# - C++ 간의 Memorymapped file 관련 Data 질문좀 드립니다 선생님 [1]
5237유호성10/1/20197096사용자 정의 컨트롤 VS IDE에서만 Exception 발생 [2]
5234koko9/25/20199340안녕하세요. 64bit WPF -> 32bit C++ DLL Import사용 문의 드립니다. [3]
5232fox3...9/24/20197148C# Memorymappedfile 재 업로드 드립니다.(실행순서 및 질문내용 정리) [7]파일 다운로드1
5231fox3...9/24/20197537C# 메모리맵드파일 관련 질문드립니다. 최소한의 재현가능코드 첨부후 재질문 드립니다. [2]파일 다운로드1
5230질문9/23/20197205C++ 로 만든 dll 을 C#에서 사용할 때 질문 [2]
5229fox3...9/23/20199602C# 메모리맵드파일 관련 질문드립니다. [2]
5227세퉁9/23/20198272WPF Textblock 폰트 크기에 따라 글자 색이 깨지는 현상이 있습니다. [3]파일 다운로드1
5226김대훈9/23/20197926정말 황당한 경우입니다.. [2]
5223김태균9/19/20197647책 소개 링크가 7.1버전판으로 이어집니다. [1]
5222냥냥이9/14/20198192프로그래밍 논리력이 많이 부족합니다 [3]
5219티지레몬9/9/20199678c# PCB 자동화 프로그램(윈도우 폼 위주로 작업) 제작 준비 [3]
... 16  17  18  19  20  21  22  23  24  25  [26]  27  28  29  30  ...