Why is 0x00000100 = 256?
Numbers that begin with 0x
are interpreted as hexadecimal (base 16) in C.
So 0x10 == 16
, and 0x100 == 256
, 0x10000 == 65536
, etc.
Powers of two are:
- 20 = 0x1
- 21 = 0x2
- 22 = 0x4
- 23 = 0x8
- 24 = 0x10
- 25 = 0x20
- 26 = 0x40
- 27 = 0x80
- 28 = 0x100
No, the 0x
means hexadecimal (i.e. base-16) and not binary, which is what you seem to be confusing it with.
If you want to use binary literals in your code, then see this SO question, which mentions the gcc extension that allows 0b00000100
to be used to represent 4
in binary.
0x00000100
is in base-16 because 0x
prefix means you are using hexadecimal notation.
So 0x00000001
= 1*160 = 1, 0x00000010
= 1*161, 0x00000100
= 1*162 = 256 and 0x00000123
= 1*162 + 2*161 + 3*160 = 256 + 32 + 3 = 291
To play with base-2, base-10 and base-16 notation, you can try this site: http://www.mathsisfun.com/binary-decimal-hexadecimal-converter.html