__attribute__(优化(0))) 是否适用于"recursively"?
Does __attribute__((optimize(0))) apply "recursively"?
假设我想使用一个函数来测量运行时,我想避免编译器仅仅因为它认为它们什么都不做而优化表达式(它们没有,除了我想测量它们需要多长时间来计算(。我没有做奇怪的噱头,比如把它加到另一个变量中等,而是在 GCC 中发现了__atribute__((optimize(0)))
。但是,假设我有以下代码:
__attribute__((optimize(0))) void test(int n) {
while (n--) {
foo();
}
}
int main() {
std::cout << Timer::measure(test).count() << "msn";
}
该属性是否会阻止编译器优化函数 foo(( 中的代码?我真的只是想测试一些运行时,并且可靠且相对容易地防止编译器完全删除代码(我希望它尽可能优化代码,但不删除它,因为它什么都不做!
这有什么意义吗?提前感谢!
我只是想我可以做一个实验(为什么我不早点想到这一点(,这是我所做的:
// toggle this
// __attribute__((optimize(0)))
void waste_time() { for (unsigned i = 100000; i--; ); }
// always leave this on
__attribute__((optimize(0)))
void test() {
for (unsigned i = 1000; i--; ) {
waste_time();
}
}
int main() {
std::cout << Timer::measure(test).count() << "msn";
}
我在 -O3 中发现了什么:
waste_time no optimizations: 196.972ms (obviously the loop is not optimized)
waste_time w/ optimizations: 0.001995ms (loop is optimized)
对我来说,这非常清楚地表明,__attribute__
不会"传播"到嵌套函数调用,因此即使 test(( 指定了属性,waste_time(( 仍然会被优化。
相关文章:
- FLTK 2.0构建和演示,适用于VS2019的2011年左右的代码库
- C++17 - 使用自定义分配器的节点提取/重新插入 - 适用于 clang++/libc++,但不适用于 libstd
- "string.h"在构建适用于iOS的qt应用程序中找不到消息
- 适用于 WebView2 旧版本的示例应用程序
- 在 NVIDIA GEFORCE GTX 1050 上下载适用于 Windows 10 的 openCL 1.2
- __attribute__(优化(0))) 是否适用于"recursively"?
- 为什么 std::erase(std::erase_if) 不是适用于<algorithm>任何容器的模板?
- 使用一个参数的模板函数时出错(适用于 2)
- 使用 适用于 Android 和 iOS 的 tf-lite C++ API
- 为什么这适用于 G++ 而不是 CLANG?
- 适用于 macOS 的 Xcode 应用程序。这就是我设置从USB麦克风输入获取音频的方式。一年前工作,现在没有了。为什么
- 适用于 Linux 的 c++ 上的代理脚本
- 为什么我的 SFINAE 表达式不再适用于 GCC 8.2?
- 使输出流式处理运算符适用于 boost::variant<std::vector<int>、int、double 的正确方法是什么>
- 有没有适用于Windows.lib文件的GNU二进制文件描述符(BFD)
- 模板函数仅适用于VS
- 如何在cmake中包含适用于g++或viceversa的库
- 适用于win32、linux、mac的POSIX C包装器
- WinDBG适用于从Visual Studio 2015保存的转储,但不适用于任务管理器。显示异常代码"not found"
- 从uint8_t到NPY_UINT16 PyArray_SimpleNewFromData.适用于Linux,但不适用于