char a, b;
printf("%d", sizeof(a+b));
What will printf write to the screen?
I thought because sizeof(char)=1, that sizeof(a+b) will be also 1, but it turned out to be 4. I don't understand this, why does it write 4 if we are adding two chars?
'a' by default is an integer and because of that you get size of int in your machine 4 bytes. char is 1 bytes and because of this you get 1 bytes.
sizeof always returns size as the number of bytes.
The char type takes 1 byte of memory (8 bits) and allows expressing in the binary notation 2^8=256 values.
Even if you think of a “character” as a multi-byte thingy, char is not. sizeof(char) is always exactly 1. No exceptions, ever.
In C language operands of almost all arithmetic operators are subjected to implicit conversions called usual arithmetic conversions or, in this case, integer promotions. Operands of type char
are promoted to type int
and the actual addition is performed within the domain of int
(or unsigned int
, depending on the properties of char
on that platform). So your a + b
is actually interpreted as (int) a + (int) b
. The result has type int
and sizeof(int)
is apparently 4 on your platform. That 4 is what you see.
And don't use %d
to printf
the result of sizeof
. The result of sizeof
has type size_t
, while %d
requires an int
argument. So, either use the proper format specifier
printf("%zu\n", sizeof(a+b));
or at least cast the argument if you are sure it fits
printf("%d\n", (int) sizeof(a+b));
This is not the same as sizeof(char)
, the argument (i.e. the result of the addition) is promoted to int
so sizeof(a + b)
is in fact equivalent to sizeof(int)
. If you cast the result to char
it will be what you expect. Also, the correct format specifier for sizeof
result which is size_t
is %zu
and not %d
.
Try
printf("%zu", sizeof((char) (a + b)));
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With