11

Possible Duplicate:
Absolute Beginner's Guide to Bit Shifting?

anyone can explain me that operator << or >>

Community
  • 1
  • 1
elgianka
  • 223
  • 2
  • 11

4 Answers4

34

The << and >> operators are bitshift operators. x << 1 shifts all the bits in x up to the next most significant bit, effectively multiplying by 2. More generally, x << n shifts the bits up n positions. To understand how this operation works it is easiest to look at the binary representation:

3         0000011 =  3
3 << 1    0000110 =  6
3 << 2    0001100 = 12
3 << 3    0011000 = 24

Similarly the >> operator shifts the bits down:

58        0111010 = 58
58 >> 1   0011101 = 29
58 >> 2   0001110 = 14
58 >> 3   0000111 = 7
58 >> 4   0000011 = 3
58 >> 5   0000001 = 1
58 >> 6   0000000 = 0
Mark Byers
  • 767,688
  • 176
  • 1,542
  • 1,434
15

3, in binary, is 11 and shifted to left one bit is 110, or 6 in decimal.

Think of a << b as a * (2 ** b)

>> is for right-shifting. Think of a >> b as a // (2 ** b)

John Machin
  • 78,552
  • 11
  • 135
  • 182
Gabi Purcaru
  • 29,852
  • 9
  • 74
  • 91
4

It's a shift operator.

http://docs.python.org/reference/expressions.html#shifting-operations

Julio Santos
  • 3,769
  • 1
  • 25
  • 47
4

It's a bit shift, using a shifting operation.

Say you have a number, and looking at the lowest bits, you have 3:

0 0 1 1

If you shift it, you'll get 6, or:

0 1 1 0

Reed Copsey
  • 539,124
  • 75
  • 1,126
  • 1,354