为什么我的程序不执行第二个 catch 块?

Why wont my program execute the second catch block?

我是异常处理的新手,这是关于我在该主题的第一个作业中遇到的问题。我故意为程序提供了数小时和数秒的无效条目以测试 try/catch,因此两者都应该抛出异常。我有点明白为什么第一个 catch 块会捕获两次抛出,但我不确定如何让它同时使用两个 catch 块?谢谢! (输出为"ERROR: INVALID HOUR ENTRY")

int main()
{
MilTime Object;
string BadHour;
string BadSeconds;

try
{
if ( (Object.getHour() < 0) || (Object.getHour() > 2359) ) throw BadHour;
if ( (Object.getSec()  < 0) || (Object.getSec()  > 59  ) ) throw BadSeconds;
}
catch (string BadHour)
{
cout << "ERROR, INVALID HOUR ENTRY";
}
catch (string BadSeconds)
{
cout << "ERROR, INVALID SECOND ENTRY";
}
return 0;

catches 是按类型区分的,而不是按参数名称区分的。

原则上你可以定义不同的异常类型,或者你可以使用例如std::system_error 允许您传递整数错误 ID。

然而,在实践中,异常的特定原因除了用于日志记录之外没有什么意义,因为它通常不会影响如何处理它。一个例外表示代码未能按照其合同规定的方式执行。 catch 只能尝试再次(可能以某种不同的方式)实现目标,否则就会失败。

您必须按数据类型捕获异常,而不是按变量名。尝试更像这样的东西:

#include <iostream>
#include <stdexcept> 

class BadHourError : public std::runtime_error
{
public:
    BadHourError() : std::runtime_error("") {}
};

class BadSecondsError : public std::runtime_error
{
public:
    BadSecondsError() : std::runtime_error("") {}
};

class MilTime
{
public:
    int getHour() const { return ...; }
    int getSec() const { return ...; }
};

int main()
{
    MilTime Object;

    try
    {
        if ( (Object.getHour() < 0) || (Object.getHour() > 2359) ) throw BadHourError();
        if ( (Object.getSec()  < 0) || (Object.getSec()  > 59  ) ) throw BadSecondsError();
    }
    catch (const BadHourError &)
    {
        std::cout << "ERROR, INVALID HOUR ENTRY";
    }
    catch (const BadSecondsError &)
    {
        std::cout << "ERROR, INVALID SECOND ENTRY";
    }

    return 0;
}

或者:

#include <iostream>
#include <string> 
#include <stdexcept> 

class BadTimeError : public std::runtime_error
{
public:
    BadTimeError(const std::string &what_arg) : std::runtime_error(what_arg) {}
};

class BadHourError : public BadTimeError
{
public:
    BadHourError() : BadTimeError("INVALID HOUR ENTRY") {}
};

class BadSecondsError : public BadTimeError
{
public:
    BadSecondsError() : BadTimeError("INVALID SECOND ENTRY") {}
};

class MilTime
{
public:
    int getHour() const { return ...; }
    int getSec() const { return ...; }
};

int main()
{
    MilTime Object;

    try
    {
        if ( (Object.getHour() < 0) || (Object.getHour() > 2359) ) throw BadHourError();
        if ( (Object.getSec()  < 0) || (Object.getSec()  > 59  ) ) throw BadSecondsError();
    }
    catch (const BadTimeError &ex)
    {
        std::cout << "ERROR, " << ex.what();
    }

    return 0;
}

如果您设置自己的类型,即结构和测试,您可以看到 try/throw/catch 确实是如何依赖于类型的,如下所示:

#include <iostream>

using namespace std;

struct BadHr 
{
};

struct BadSec 
{
};

int main()
{
    int test = 2;

    try
    {
        if (test == 1) throw BadHr();
        if (test == 2) throw BadSec();
    }
    catch (BadHr& e)
    {
        std::cout << "Bad hour" << std::endl;
    }
    catch (BadSec& e)
    {
        std::cout << "Bad Sec" << std::endl;
    }


}