编译器是否优化出乘法为1的乘法?也就是说,考虑一下:
int a = 1;
int b = 5 * a;表达式5 *a会被优化为只有5吗?若否,会否将a定义为:
const int a = 1;发布于 2008-10-02 04:07:41
它将在编译时预先计算任何常量表达式,包括字符串连接。如果没有const,它将被单独使用。
您的第一个示例编译为这个IL:
.maxstack 2
.locals init ([0] int32, [1] int32)
ldc.i4.1 //load 1
stloc.0 //store in 1st local variable
ldc.i4.5 //load 5
ldloc.0 //load 1st variable
mul // 1 * 5
stloc.1 // store in 2nd local variable 第二个示例编译为:
.maxstack 1
.locals init ( [0] int32 )
ldc.i4.5 //load 5
stloc.0 //store in local variable发布于 2008-10-02 04:09:09
常量传播是最常见和最简单的优化方法之一。
发布于 2008-10-02 04:35:31
查看由mono编译器生成的代码,带有非常数a的版本在运行时执行乘法运算。也就是说,乘法没有优化出来。如果你做了一个const,那么乘法就会被优化出来。
Microsoft编译器可能有一个更积极的编译器,最好的解决方案是查看编译器生成的代码,看看它在做什么。
https://stackoverflow.com/questions/160848
复制相似问题