xib*_*ibu 14 c c++ compiler-optimization
由于有符号整数溢出是未定义的行为,我希望下面的三个函数编译为相同或相似的程序集。然而事实并非如此。与其他示例test2略有不同,test1并test3使用了两条imul不需要的指令。
int test1(int x)
{
return x * 5 / 2;
}
int test2(int x)
{
return x * 10 / 4;
}
int test3(int x)
{
return x * 50 / 20;
}
Run Code Online (Sandbox Code Playgroud)
编译器不执行这种优化是否有原因?
这种优化是否正确将取决于实现对整数溢出影响的保证(如果有的话):
x*(m*a)/(m*b)将x*a/b违反此类保证。gcc 编译器提供了一些选项,要么支持强保证选项#1,要么不提供任何保证,并且整数溢出破坏不使用结果的代码部分的可能性不仅仅是理论上的。因为选项 #3 对于从潜在不可信来源接收输入的程序来说是非常危险的,并且因为 gcc 不提供 #1 和 #3 之间的任何设置,所以许多程序,包括那些选项 #2 满足要求的程序,使用fwrapv强制选项 #1 的标志构建。