Search code examples
cbit-shiftbitlow-level

Shifting a 32 bit integer by 32 bits


I'm slinging some C code and I need to bitshift a 32 bit int left 32 bits. When I run this code with the parameter n = 0, the shifting doesn't happen.

int x = 0xFFFFFFFF;
int y = x << (32 - n);

Why doesn't this work?


Solution

  • Shift at your own peril. Per the standard, what you want to do is undefined behavior.

    C99 §6.5.7

    3 - The integer promotions are performed on each of the operands. The type of the result is that of the promoted left operand. If the value of the right operand is negative or is greater than or equal to the width of the promoted left operand, the behavior is undefined.

    In other words, if you try to shift a 32bit value by anything more than 31 bits, or a negative number, you're results are undefined.