예외가 없는 경우 .NET에서 스택 추적 로깅
코드를 디버깅할 때 현재 스택 추적을 인쇄하는 것은 오류를 이해하는 데 매우 중요할 수 있습니다. 프로그램 흐름 및 문제 식별. 그러나 예외가 발생하지 않은 상황에서는 try-catch 블록이나 Exception.StackTrace 속성을 사용하는 표준 접근 방식이 작동하지 않습니다.
해결책
예외 없이 현재 스택 추적을 인쇄하려면 System.Diagnostics.StackTrace 클래스를 활용하세요.
System.Diagnostics.StackTrace t = new System.Diagnostics.StackTrace();
현재 실행 중인 메소드, 호출자 등에 대한 정보를 프로그램 진입점까지 포함합니다.
예
다음 코드를 고려하세요.
public void executeMethod() { logStackTrace(); method(); }
executeMethod()를 호출한 다음 스택 추적을 인쇄하면 뭔가를 볼 수 있습니다. like:
at executeMethod() in C:\Path\To\MyCode.cs:line 10 at method() in C:\Path\To\MyCode.cs:line 15 at Program.Main() in C:\Path\To\MyMain.cs:line 20
이 추적은 예외가 발생하지 않았더라도 호출 스택을 보여줍니다.
추가 리소스
추가 디버깅 도구 에서 System.Diagnostics 네임스페이스를 살펴보세요. NLog, log4net 및 Enterprise Library와 같은 로깅 프레임워크는 스택 추적 캡처 기능을 포함하여 포괄적인 로깅 솔루션을 제공합니다.
위 내용은 예외 없이 .NET에서 스택 추적을 기록하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!