If vs. Switch Speed
This is a slight simplification as typically any modern compiler that encounters a if..else if ..
sequence that could trivially be converted into a switch statement by a person, the compiler will as well. But just to add extra fun the compiler is not restricted by syntax so can generate "switch" like statements internally that have a mix of ranges, single targets, etc -- and they can (and do) do this for both switch and if..else statements.
Anyhoo, an extension to Konrad's answer is that the compiler may generate a jump table, but that's not necessarily guaranteed (nor desirable). For a variety of reasons jump tables do bad things to the branch predictors on modern processors, and the tables themselves do bad things to cache behaviour, eg.
switch(a) { case 0: ...; break; case 1: ...; break; }
If a compiler actually generated a jump table for this it would likely be slower that the alternative if..else if..
style code because of the jump table defeating branch prediction.
The compiler can build jump tables where applicable. For example, when you use the reflector to look at the code produced, you will see that for huge switches on strings, the compiler will actually generate code that uses a hash table to dispatch these. The hash table uses the strings as keys and delegates to the case
codes as values.
This has asymptotic better runtime than lots of chained if
tests and is actually faster even for relatively few strings.