什么是在.NET中划分两个整数值并获得浮点商的最高效方法?

时间:2008-11-12 09:03:23

标签: .net performance floating-point division integral

在C#中考虑以下签名:

double Divide(int numerator, int denominator);

以下实施之间是否存在性能差异?

return (double)numerator / denominator;

return numerator / (double)denominator;

return (double)numerator / (double)denominator;

我假设上述两种情况都会返回相同的答案。

我是否错过了其他任何等效解决方案?

2 个答案:

答案 0 :(得分:5)

您是否尝试过比较IL(例如,使用Reflector)?

static double A(int numerator, int denominator)
{ return (double)numerator / denominator; }

static double B(int numerator, int denominator)
{ return numerator / (double)denominator; }

static double C(int numerator, int denominator)
{ return (double)numerator / (double)denominator; }

这三个人都成了(给出或取名):

.method private hidebysig static float64 A(int32 numerator, int32 denominator) cil managed
{
    .maxstack 8
    L_0000: ldarg.0 // pushes numerator onto the stack
    L_0001: conv.r8 // converts the value at the top of the stack to double
    L_0002: ldarg.1 // pushes denominator onto the stack
    L_0003: conv.r8 // converts the value at the top of the stack to double
    L_0004: div     // pops two values, divides, and pushes the result
    L_0005: ret     // pops the value from the top of the stack as the return value
}

所以不是:差别确实是零。

答案 1 :(得分:1)

即使您使用VB.NET,在进行实际除法之前,分子和分母都会转换为双精度数,因此您的示例是相同的。