这个被优化了吗?
Does this get optimized out?
本文关键字:优化 更新时间:2023-10-16
assert宏是这样的:
#ifdef DEBUG
#define ASSERT(x) ((void)(!(x) && assert_handler(#x, __FILE__, __LINE__) && (exit(-1), 1)))
#else
#define ASSERT(x) ((void)sizeof(x))
我认为这或多或少是防弹的,但我似乎在断言函数的返回值的上下文中使用了很多,这对它们的副作用很重要。如果在我的发布版本中我最终编译了
ASSERT(fgets(buffer,sizeof(buffer)/sizeof(buffer[0]),file));
变成
((void)sizeof(fgets(buffer,sizeof(buffer)/sizeof(buffer[0]),file)));
是否有机会得到完全优化?我相当确定它不会(我调用一个函数,fgets
),但究竟是什么条件保证它?是否有任何操作有副作用,优化器可能会抛出?
这与优化无关。当对sizeof
表达式求值时,操作数永远不会被求值。例如,
char func(void) { exit(1); }
size_t sz = sizeof(func());
// same as
size_t sz = 1;
如果你想保留副作用而不产生编译器警告,你可以强制转换到void
,正如Neil G在他的回答中所指出的。
assert的通常含义是要优化出来的,因此最好坚持这些语义并执行
#else
#define ASSERT(x)
#endif
如果你坚持它不被优化,为什么不直接做
#else
#define ASSERT(x) ((void)(x))
#endif
?
相关文章:
- 空基优化子对象的地址
- 关闭||运算符优化
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- 返回值优化:显式移动还是隐式
- 人脸跟踪arduino代码的优化
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 纯函数,为什么没有优化
- 为什么大多数 pair 实现默认不使用压缩(空基优化)?
- 如何以优化的方式同时迭代两个间距不相等的数组
- 小字符串优化(调试与发布模式)
- 浮点定向舍入和优化
- Visual Studio 调试优化如何工作?
- 为什么开关的优化方式与 c/c++ 中的链接不同?
- 线性优化目标函数中的绝对值
- GCC 会优化内联访问器吗?
- gcc 如何优化此循环?
- 如何防止 CUDA-GDB 中的<优化输出>值
- 为什么我的程序在 O0 和 O2 的优化级别返回不同的结果
- 这个C++编译器优化(在自身的实例上调用对象自己的构造函数)的名称是什么,它是如何工作的?
- 使用 std::p air 进行返回值优化