我是一个前Pascal的人,目前正在学习c#。 我的问题是:

下面的代码比转换更快吗?

int a = 5;

if (a == 1)
{
    ....
}
else if(a == 2)
{
    ....
}
else if(a == 3)
{
    ....
}
else if(a == 4)
{
    ....
}
else
    ....

还有开关:

int a = 5;

switch(a)
{
    case 1:
        ...
        break;

    case 2:
        ...
        break;

    case 3:
        ...
        break;

    case 4:
        ...
        break;

    default:
        ...
        break;


}

哪一个更快?

我之所以这样问,是因为我的程序具有类似的结构(许多许多“else if”语句)。 我应该把它们变成开关吗?


当前回答

我想说转换是正确的方法,它既更快又更好。

下面的链接显示了比较这两者的基准测试。

其他回答

就少数几项而言,差别很小。如果你有很多东西,你一定要用开关。

如果一个开关包含五个以上的项,则使用查找表或散列表来实现。这意味着所有的条目都有相同的访问时间,而在if:s列表中,最后一个条目需要更多的时间才能到达,因为它必须先评估之前的每个条件。

相信这个性能评估,切换的情况是更快的。

结论如下:

结果表明,switch语句比if-else-if阶梯语句执行得更快。这是由于编译器优化switch语句的能力。在if-else-if阶梯的情况下,代码必须按照程序员确定的顺序处理每个if语句。但是,由于switch语句中的每个用例都不依赖于之前的用例,因此编译器能够以提供最快执行的方式重新排序测试。

如果可能的话,Switch通常会被编译器转换成一个查找表。所以任意情况的查找是O(1)而不是在找到你想要的情况之前做一些情况比较。

所以在很多情况下if/else if链会慢一些。不过,这取决于你的箱子被击中的频率,可能没有什么区别。

应该不难测试,创建一个在5个数字之间切换或ifelse的函数,在该函数中放入rand(1,5),并在计时时循环几次。

看到 http://msdn.microsoft.com/en-us/library/system.reflection.emit.opcodes.switch%28VS.71%29.aspx

Switch语句基本上是一个查找表,它有已知的选项,if语句类似于布尔类型。根据我的说法,开关和if-else是一样的,但对于逻辑开关可以帮助更好。而if-else在阅读中也有助于理解。