예외 처리는 C에서 오류와 비정상적인 상황을 효과적으로 관리할 수 있는 중요한 기술입니다. 견고하고 안정적인 코드를 작성하려면 예외를 발생시키고 시도하고 포착하는 방법을 이해하는 것이 필수적입니다.
예외가 유용한 일반적인 시나리오 중 하나는 정상적인 프로그램 실행 중에 발생해서는 안 되는 잘못된 입력이나 조건을 처리하려는 경우입니다. . 예를 들어 두 정수를 비교하는 비교(int a, int b) 함수를 생각해 보겠습니다.
a 또는 b가 음수인 경우를 처리하려면 비교 함수의 정의를 다음과 같이 수정할 수 있습니다.
#include <stdexcept> int compare(int a, int b) { if (a < 0 || b < 0) { throw std::invalid_argument("received negative value"); } }
이 예에서는 매개변수 중 하나라도 음수인 경우 예외를 발생시키기 위해 throw 문을 사용합니다. std::invalid_argument는 함수에 전달되는 유효하지 않은 인수에 해당하는 내장 예외 개체입니다.
비교 함수에서 발생한 예외를 처리하려면 try-catch 블록을 사용할 수 있습니다.
try { compare(-1, 3); } catch (const std::invalid_argument& e) { // Handle the exception here... }
try 블록 내에서 잠재적으로 유효하지 않은 입력으로 비교 기능을 실행하려고 시도합니다. 예외가 발생하면 catch 블록이 이를 포착하여 예외 객체 e에 대한 참조를 제공합니다. 이 객체를 사용하여 예외의 원인을 파악하고 적절한 조치를 취할 수 있습니다.
또한 C는 예외 처리에 유연성을 제공합니다. 위의 예에서 설명한 것처럼 값으로 던지고 참조로 잡을 수 있습니다. catch(...)를 사용하여 유형에 관계없이 예외를 다시 발생시키거나 예외를 포착할 수도 있습니다. 이러한 기능을 통해 사용자 정의되고 효율적인 방식으로 예외 시나리오를 처리할 수 있습니다.
위 내용은 잘못된 입력을 처리하기 위해 C에서 예외를 어떻게 발생시키고 포착합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!