>백엔드 개발 >C++ >C 소멸자가 `std::nested_Exception`으로 예외를 던질 수 없는 이유는 무엇입니까?

C 소멸자가 `std::nested_Exception`으로 예외를 던질 수 없는 이유는 무엇입니까?

DDD
DDD원래의
2024-11-03 20:40:29966검색

Why Can't C   Destructors Throw Exceptions with `std::nested_exception`?

C가 소멸자로부터의 throw를 허용하기 위해 std::nested_Exception을 사용하지 않는 이유는 무엇입니까?

std::nested_Exception을 사용하지 않는 주된 이유 소멸자로부터 예외 발생을 용이하게 하는 것은 또 다른 예외가 "실행 중"일 때 잠재적인 모호성에 있습니다. 소멸자 실행 중에 예외가 이미 활성화된 경우 상황을 처리하는 방법이 불분명합니다. 기존 예외를 새 예외로 덮어쓰는 것이 잠재적인 해결책을 제시하지만, C 커뮤니티 내의 합의에서는 대신 std::terminate 또는 사용자 정의 std::terminate_handler를 호출하는 것을 선호했습니다.

중첩 예외 탐색

내포된 예외를 사용하는 아이디어가 고려되었지만 잠재적인 구현 문제로 인해 채택이 방해를 받았을 수 있습니다. 특히 잠재적인 성능 영향과 예외 처리의 복잡성 증가에 대한 우려가 현재 접근 방식을 유지하기로 결정하는 데 영향을 미쳤을 수 있습니다.

향후 개발

C 기준 17에서는 중첩 예외를 사용하는 소멸자에서 예외 던지기를 허용하는 입장이 변경되지 않았습니다. 그러나 향후 C 버전에서는 이 개념을 다시 검토하고 객체 소멸 중 예외 문제를 해결하기 위한 대체 솔루션을 도입할 수도 있습니다.

위 내용은 C 소멸자가 `std::nested_Exception`으로 예외를 던질 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.