처리되지 않은 예외의 소스 공개
프로그램 실행 중에 예외가 발생하면 원인을 추적하는 것이 문제 해결에 매우 중요할 수 있습니다. 예외 메시지에 명시적인 코드 줄 정보가 포함되어 있지 않으면 처리되지 않은 외부 예외로 인해 개발자가 어려움을 겪을 수 있습니다.
사용자 지정 예외 및 매크로에 대한 심층 분석
이 문제를 해결하기 위해 강력한 솔루션에는 사용자 정의 예외 클래스를 생성하고 매크로를 활용하는 것이 포함됩니다.
my_Exception 클래스는 std::runtime_error 클래스를 확장하고 추가 msg 멤버를 통합하여 예외 메시지를 저장합니다. 이 클래스의 생성자는 소스 파일, 줄 번호 및 원래 예외 인수를 연결하여 메시지를 구성합니다.
다음으로, throw_line 매크로는 줄 정보를 사용하여 예외를 발생시키는 프로세스를 단순화합니다. 예외 메시지를 나타내는 인수를 취하고 파일 및 줄 번호 세부 정보를 my_Exception 개체에 자동으로 추가합니다.
작업에 적용
다음 코드 조각을 고려하세요.
void f() { throw_line("Oh no!"); } int main() { try { f(); } catch (const std::runtime_error &ex) { std::cout << ex.what() << std::endl; } }
f 함수 내에서 예외가 발생하면 throw_line 매크로는 예외 메시지("안돼!")와 예외가 발생한 줄 번호를 모두 제공합니다. 이 정보는 my_Exception 개체의 what() 메서드를 통해 액세스할 수 있습니다.
이 접근 방식을 활용하면 개발자는 예외가 처리되지 않거나 외부 소스에서 발생한 경우에도 예외의 소스를 정확하게 식별할 수 있는 귀중한 도구를 얻을 수 있습니다.
위 내용은 처리되지 않은 예외를 찾아내는 방법: 사용자 지정 예외 및 매크로에 대한 심층 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!