在C++中,递归函数可以通过以下方法进行错误处理:
try
、catch
和throw
关键字来捕获和处理异常。在递归函数中,当遇到错误时,可以抛出一个异常并在调用栈中向上抛出,直到被捕获为止。#include <iostream>
#include <stdexcept>
int factorial(int n) {
if (n < 0) {
throw std::invalid_argument("Invalid input: n must be non-negative.");
}
if (n == 0 || n == 1) {
return 1;
}
return n * factorial(n - 1);
}
int main() {
try {
int result = factorial(-1);
std::cout << "Result: " << result << std::endl;
} catch (const std::invalid_argument& e) {
std::cerr << "Error: " << e.what() << std::endl;
}
return 0;
}
#include <iostream>
enum class ErrorCode {
SUCCESS,
INVALID_INPUT
};
ErrorCode factorial(int n, int& result) {
if (n < 0) {
return ErrorCode::INVALID_INPUT;
}
if (n == 0 || n == 1) {
result = 1;
return ErrorCode::SUCCESS;
}
result = n * factorial(n - 1, result);
return ErrorCode::SUCCESS;
}
int main() {
int result;
ErrorCode errorCode = factorial(-1, result);
if (errorCode != ErrorCode::SUCCESS) {
std::cerr << "Error: Invalid input." << std::endl;
} else {
std::cout << "Result: " << result << std::endl;
}
return 0;
}
assert
宏来检查程序的假设和不变式。如果假设不成立,程序将终止并显示错误消息。这种方法适用于调试阶段,但在发布版本中可能会被禁用。#include <iostream>
#include <cassert>
int factorial(int n) {
assert(n >= 0 && "Invalid input: n must be non-negative.");
if (n == 0 || n == 1) {
return 1;
}
return n * factorial(n - 1);
}
int main() {
int result = factorial(-1); // This will cause the program to terminate with an error message
std::cout << "Result: " << result << std::endl;
return 0;
}
请注意,异常处理和错误码方法更适用于复杂的递归函数,而断言方法更适用于简单的调试场景。在实际项目中,应根据具体需求选择合适的错误处理方法。