- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
在C++中,是如下代码
try {
foo();
} catch (...) {
throw;
}
在语义上等同于像这样调用 foo
吗?
foo();
如果是这样,我是否可以期望最先进的编译器避免第一个版本到第二个版本(在启用优化的情况下编译时)?
换句话说,如果我使用 NDEBUG
编译这段代码并启用优化
try {
foo();
} catch (...) {
assert(some_check());
throw;
}
我可以假设这个丑陋的版本永远不会慢吗
#ifndef NDEBUG
try {
#endif
foo();
#ifndef NDEBUG
} catch (...) {
assert(some_check());
throw;
}
#endif
最佳答案
不,两者不等同。
当没有异常处理程序时是否展开堆栈是实现定义的([except.handle]p9)。当处理程序存在时,但它只是重新抛出异常,堆栈必须至少在重新抛出异常之前展开。
即:
struct S { ~S(); };
void foo() { S s; throw 0; }
int main() {
try { foo(); }
catch(...) { throw; }
}
这必须调用s
的析构函数。当 try { ... } catch (...) { throw;
被移除,不再需要调用 s
的析构函数。
甚至有可能,根据 s
的析构函数的作用,执行永远不会到达异常的重新抛出,通过添加例如:
#include <stdlib.h>
S::~S() { exit(0); }
现在,程序必须成功运行,但是当 try { ... } catch (...) { throw;
已删除,不再需要,并且在真实系统上可能并且确实会发生崩溃。
关于C++:可以将 "try { foo(); } catch (...) { throw; }"优化为 "foo();"吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39885813/
出于好奇,我尝试了一些原型(prototype)制作,但似乎只允许在第一个位置使用子例程的原型(prototype) &。 当我写作时 sub test (&$$) { do_somethin
我需要开发一个类似于 Android Play 商店应用程序或类似 this app 的应用程序.我阅读了很多教程,发现几乎每个教程都有与 this one 类似的例子。 . 我已经开始使用我的应用程
考虑一个表示“事件之间的时间”的列: (5, 40, 3, 6, 0, 9, 0, 4, 5, 18, 2, 4, 3, 2) 我想将这些分组到 30 个桶中,但桶会重置。期望的结果: (0, 1,
我是一名优秀的程序员,十分优秀!