C#:(float)(x / y)和x /(float)y之间有区别吗?

时间:2012-09-28 15:33:45

标签: c# casting floating-point

我想知道以下表达式是否相同(在C#中):

float x = ... ;
int y = ... ;

var result = (float) (x / y);

Versus:

var result = x / (float)y;

我在哪里可以阅读有关此特定主题的更多信息?

我感兴趣的是:

  1. 这些会不会产生相同的结果?
  2. 一个选项的效果是否比另一个更有效?

2 个答案:

答案 0 :(得分:9)

是的,他们的行为方式相同。事实上,你可以使用:

var result = x / y;

float result = x / y;

C#4规范的第7.8.2节显示哪些除法运算符是可用的 - 并且没有float operator /(float, int)运算符。相反,C#编译器使用从intfloat的隐式转换,并使用float operator /(float, float)运算符。

这只是普通的操作符重载决策(规范部分7.3.4)和隐式数字转换(规范部分6.1.2)。

如有疑问,请参阅规格。我有web page with links to the different versions; C#5规范与VS 2012捆绑在一起,但现在没有单独的下载。

答案 1 :(得分:7)

完全没有区别。生成的IL代码完全相同:

以下是IL Disassembler为两种变体返回的内容:

// Code size       16 (0x10)
.maxstack  2
.locals init ([0] float32 x,
         [1] int32 y,
         [2] float32 result)
IL_0000:  nop
IL_0001:  ldc.r4     1.5
IL_0006:  stloc.0
IL_0007:  ldc.i4.1
IL_0008:  stloc.1
IL_0009:  ldloc.0
IL_000a:  ldloc.1
IL_000b:  conv.r4
IL_000c:  div
IL_000d:  conv.r4
IL_000e:  stloc.2
IL_000f:  ret