- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
从其他线程,我知道我们不应该在析构函数中抛出异常!但是对于下面的例子,它确实有效。这是否意味着我们只能在一个实例的析构函数中抛出异常?我们应该如何理解这个代码示例!
#include
sử dụng không gian tên std;
class A {
công cộng:
~A() {
thử {
printf("exception in A start\n");
throw 30;
printf("exception in A end\n");
}catch(int e) {
printf("catch in A %d\n",e);
}
}
};
class B{
công cộng:
~B() {
printf("exception in B start\n");
throw 20;
printf("exception in B end\n");
}
};
int main(void) {
thử {
A a;
B b;
}catch(int e) {
printf("catch in main %d\n",e);
}
trả về 0;
}
输出是:
exception in B start
exception in A start
catch in A 30
catch in main 20
1 Câu trả lời
C++17 之前的最佳实践是不要让异常从析构函数中传播。如果析构函数包含 ném
表达式或调用可能抛出的函数,只要捕获并处理抛出的异常而不是从析构函数中转义就可以了。所以你的 A::~A
没问题。
vì B::~B
,您的程序在 C++03 中没有问题,但在 C++11 中却不行。规则是,如果您Thực ra让异常从析构函数中传播出来,并且该析构函数是针对一个自动对象的,该对象直接被堆栈展开销毁,那么std::terminate
将被调用。由于 b
没有作为栈展开的一部分被销毁,从 B::~B
抛出的异常将被捕获。但在 C++11 中,B::~B
析构函数将被隐式声明为 noexcept
,因此,允许异常从中传播出去将调用 std::terminate
无条件。
要允许在 C++11 中捕获异常,您可以这样写
~B() noexcept(false) {
// ...
}
不过,在堆栈展开期间可能会调用 B::~B
的问题——在这种情况下,std::terminate
将是叫。因为在 C++17 之前,没有办法判断是否是这种情况,所以建议永远不要让异常传播到析构函数之外。遵守这条规则,你会没事的。
在 C++17 中,可以使用 std::uncaught_exceptions()
检测对象是否在堆栈展开期间被销毁。但你最好知道自己在做什么。
关于析构函数中的c++异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41174167/
我开始考虑在我 future 的项目或重构中实现控制反转容器,我想知道在正确设计依赖项时哪些原则(除了 GoF 模式)可能需要牢记在心。假设我需要构建一个简单的控制台应用程序,如果它可以访问互联网,它
假设我有一个 RxC contingency table 。这意味着有 R 行和 C 列。我想要一个维度为 RC × (R + C − 2) 的矩阵 X,其中包含行的 R − 1 “主效应”以及列的
我正在尝试使用 DKMS 为正在运行的内核 (4.4) 构 build 备树覆盖。我天真的 Makefile 如下: PWD := $(shell pwd) dtbo-y += my-awsome-o
我有一个 sencha touch 项目。我是用 phonegap 2.9 构建的,并且可以正常工作 device.uuid 返回到设备 ID。当我尝试使用 3.1 device.uuid 构建时抛出
我在安装了 Xcode 4.5.1 的 Mt Lion 上运行。 默认情况下,当我构建并部署到 iOS 5.1 设备时,显示会在我旋转设备时旋转,但当我部署到 iOS 6 模拟器或运行 iOS 的 i
我正在尝试使用 Google Analytics Reporting API v4 构建多折线图。 一张图表,其中我按每天的 session 计数为每个设备(台式机/平板电脑/移动设备)设置了一条线。
我一生都无法使用 xcode 组织者“自动设备配置”中的“团队配置配置文件”在 xcode 4.0.1 中将我的应用程序构建到我的 iPad 上。 该应用程序完美地构建到模拟器,但当我构建到 iPad
Tôi là một lập trình viên xuất sắc, rất giỏi!