正确的解法是:
a = b + ( b = a ) * 0
首先编译器根据运算符优先级,先找到这个里面最优先的运算符*,确定结合顺序如下:
a = ( b + ( ( b = a ) * 0 ) )
接下来,根据C#规范,会从左至右计算每个子表达式的值,第一个子表达式b,值为当前b值,记为b ',第二个子表达式b = a,值为当前a值,记为a ',最后一个表达式0,值为0。
接下来,根据刚才确定的顺序,依次进行计算。
b = a已经运算完毕,值为a ',这时进行乘法运算,然后进行加法运算,然而C#的编译器意识到这个加法是没有意义的,故而优化掉,所以,整个表达式被优化为:
a = b '
加上刚才计算子表达式的值时计算的b = a。
故而C#的编译器做出了最简的IL代码。
a = b + ( b = a ) * 0
首先编译器根据运算符优先级,先找到这个里面最优先的运算符*,确定结合顺序如下:
a = ( b + ( ( b = a ) * 0 ) )
接下来,根据C#规范,会从左至右计算每个子表达式的值,第一个子表达式b,值为当前b值,记为b ',第二个子表达式b = a,值为当前a值,记为a ',最后一个表达式0,值为0。
接下来,根据刚才确定的顺序,依次进行计算。
b = a已经运算完毕,值为a ',这时进行乘法运算,然后进行加法运算,然而C#的编译器意识到这个加法是没有意义的,故而优化掉,所以,整个表达式被优化为:
a = b '
加上刚才计算子表达式的值时计算的b = a。
故而C#的编译器做出了最简的IL代码。