孤立代码块在结构中引发异常

Orphan code block throwing Exception in struct

本文关键字:异常 结构 代码      更新时间:2023-10-16

我最近在一次采访中被问到这个问题。在代码下面,询问了代码片段的行为。我提到代码抛出一个会被捕获的异常,但结果并不是正确的答案。

我试着调试了这段代码片段,有两个问题。

1。如果执行确实进入了try{A A;}行,那么为什么catch无法捕获异常?

2。这段不属于结构中任何方法的孤立代码的行为是什么?如果我放入孤立代码被包括在B的构造函数方法下,即在B(({}内部,则异常被正确捕获。那么如何执行流处理这个?我的意思是,B中的孤立代码try-catch属于哪个方法/函数堆栈?

#include<iostream>
#include<string>
using namespace std;
struct A
{
A()
{
throw 2;
}
};
struct B
{
B()
// start of orphan code.
try
{
A a;
}
catch(int i)
{
cout << i << endl;
}
// end of orphan code.
};
int main(int argc, char* argv[])
{
B b;
cout << "3" << endl;
return(0);
}

您所称的"孤立代码"实际上是一个函数try块。当与构造函数和析构函数一起使用时,这样的块有一种特殊的行为:每个catch块都隐式地重新抛出异常,就好像最后一条语句是throw;一样。这样做是为了使无法使用未能完成构建的对象。