【问题标题】:C++ Exception "Skips" Try-Catch Clause in MSVC x64MSVC x64 中的 C++ 异常“跳过”Try-Catch 子句
【发布时间】:2023-03-25 00:07:01
【问题描述】:

我正在用 C++ 编写程序。该程序在 Win32 (x86) 上运行良好,最近我尝试为 x64 本地编译它。当然,事情并没有立即奏效。

在调试问题后,我设法用这个简单的代码 sn-p 重现它:

class MyException { };

int main()
{
    try {
        for (;;) {
            try {
                std::cout << "Throwing" << std::endl;

                throw MyException();

                if (1 == 0) {
                    continue;
                }
            } catch (const MyException&) {
                std::cout << "Catch 1" << std::endl;
            }
        }
    } catch (const MyException&) {
        std::cout << "Catch 2" << std::endl;
    }

    std::cout << "Done" << std::endl;

    return 0;
}

(我很快就会解释if (1==0)子句)

使用 MSVC for x86 编译此代码时(我使用的是 2010),结果符合预期:

Throwing
Catch 1
Throwing
Catch 1
Throwing
Catch 1
Throwing
Catch 1
...

以此类推,无限循环。

但是,为 x64 编译此代码会导致:

Throwing
Catch 2
Done

异常完全跳过了内部的catch子句!

只有在我的代码中存在if (1 ==0) 子句时才会发生这种情况。当我删除它时,异常会按预期在“Catch 1”中捕获。

我尝试过使用其他编译器:

  • 这个错误也发生在 VS 2012 中。
  • MinGW 和 MinGW-w64 按预期工作。

我的问题:这是一个 MSVC 错误,还是我缺少的 C++ 中的一些未定义行为? 如果这确实是一个 MSVC 错误,我很想听听有关原因的一些见解。

谢谢。

【问题讨论】:

  • 几乎可以肯定是编译器错误,如果您在 MS Connect 提交错误报告(您可以链接此问题)并在此处留下链接,那么我会支持它。很高兴看到 Microsoft 工程师对此有何评论。
  • 不错的发现!我刚刚试了一下。首先,它会在 64 位发布版本中使链接器崩溃。其次,我可以只用continue 复制它。围绕它的if 声明是不必要的。使用VS2012更新3。
  • 我在MS Connect 上打开了一个错误报告。
  • 在 VS2013 发布版本中生成内部编译器错误,绝对是编译器错误。
  • 我以前见过这种行为。那是很久以前的事了,我记得它特别是一个编译器错误。 解决方法有一个明确的原因。但是,如果我能再次找到它,我会被诅咒的。那是很久以前的事了。抱歉,我无法为您提供更具体的信息,但这绝对是一个错误(之前遇到过)。

标签: c++ windows exception visual-c++ 64-bit


【解决方案1】:

这个错误可能与编译器优化有关——有趣的是,链接器在您的发布版本中崩溃(理论上会打开完全优化时)。

您的调试版本是否已完全禁用优化 (/Od)?

Visual Studio 帮助还包含一条声明(在“优化最佳实践”下),不鼓励 64 位代码中的 try/catch 块。

如果您在发布版本中关闭优化,链接器不会崩溃。如果您仅删除“继续”语句,它也不会崩溃(但会重现不良行为)。

if (1==0) {
//continue;
}

【讨论】:

    【解决方案2】:

    试试开关 /FAs 开关:

    http://msdn.microsoft.com/en-us/library/367y26c6%28v=vs.80%29.ASPX

    “编译器设置”中“附加输出文件”的某个位置。 (确保所有其他设置相同)

    然后,在两个输出之间做一个差异。在这里发布差异。我相信有些人会告诉你原因和方法,也许还有一些编译器设置或代码解决方法。

    【讨论】:

      【解决方案3】:

      【讨论】:

      • 链接指向一个 C# 问题 - 问题是关于 C++
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2013-04-15
      • 1970-01-01
      • 2014-09-09
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-05-04
      相关资源
      最近更新 更多