在C++中,operator()
通常用于定义函数对象的调用操作。为了处理异常,您可以在operator()
内部使用try-catch
语句来捕获和处理异常。下面是一个简单的示例:
#include <iostream>
#include <functional>
#include <stdexcept>
class MyFunctor {
public:
int operator()(int a, int b) {
try {
if (b == 0) {
throw std::runtime_error("Division by zero");
}
return a / b;
} catch (const std::runtime_error& e) {
std::cerr << "Caught exception: " << e.what() << std::endl;
return -1; // 返回一个错误码,表示发生了异常
}
}
};
int main() {
MyFunctor myFunctor;
int result = myFunctor(10, 0); // 这里会抛出异常
if (result == -1) {
std::cout << "An exception occurred" << std::endl;
} else {
std::cout << "Result: " << result << std::endl;
}
return 0;
}
在这个示例中,我们定义了一个名为MyFunctor
的类,它重载了operator()
以执行除法操作。在operator()
内部,我们使用try-catch
语句捕获可能的异常。如果除数为零,我们抛出一个std::runtime_error
异常。在catch
块中,我们捕获异常并输出错误信息,然后返回一个错误码(在这里是-1)以表示发生了异常。
在main
函数中,我们创建了一个MyFunctor
对象并调用它。由于除数为零,将抛出异常。我们检查返回值是否为-1,以确定是否发生了异常,并相应地输出错误信息。