C/C++ most efficient if statement evaluation

3.1k Views Asked by At

X is true nearly 99.9% of the time but I need to handle Y and Z as well. Although the body of the X condition is empty, I'm thinking it should be faster than potentially checking 2 other conditions Y and Z if the X condition is omitted. What do you think?

if (likely(X))
{
}
else if (unlikely(Y))
{
...
}
else if (unlikely(Z))
{
...
}
4

There are 4 best solutions below

0
On BEST ANSWER

You might want to know what exactly happens when you use likely or unlikely:
http://kerneltrap.org/node/4705

I would personally write

if (unlikely(!X))
{
  if (unlikely(Y))
  {
  ...
  }
  else if (unlikely(Z))
  {
   ...
  }
}

Which means if x, continue execution, else jump to if body.

0
On

If a compiler is to assume, it would generally favor the first condition true.

you can use something like __builtin_expect to control this (as Ugo detailed).

If it's in a loop, you should measure because hardware is also a consideration -- it's not just the source and the compiler. How's your cache, and how's branch prediction working for you? Profile. Alter. Profile. Compare.

4
On

As usual, when in doubt profile; anyhow, if I were to read that code I would find much clearer something like:

if (!likely(X))
{
    if (unlikely(Y))
    {
    ...
    }
    else if (unlikely(Z))
    {
    ...
    }
}
0
On

Do you really need the unlikely's on y and z? It sounds from your question like if x is not true, then y or z must be true, in which case those unlikely's are incorrect and I would go with this:

if (unlikely(!X))
{
  if (Y)
  {
  ...
  }
  else //Z must be true
  {
   ...
  }
}

(Would have made this a comment on Ugo's answer, but I don't have enough reputation to leave comments.)