计算机里面的数是用二进制表示的。最左边的一位指示了该整数的符号性,无符号的整数使用该位表示数值,有符号的整数使用该位表示这个数是正数还是负。
对于有符号的数值: 2的补码表示法是常用的方法。以 k 位的数字为例, 负整数 -n(1 <= n <= (2^k-1))2的补码的表示方法为: 2的k次方减n.
对于无符号的整数值: p(0 <= p <= (2^k-1)-1)通过k-1位进行编码.
这样就带来了问题:
假设有变量 int8_t的值为 0100,1110(即十进制的78).如果将该值赋值给一个int16_t类型的变量,则该变量的值为 0000,0000,0100,1110.
但是如果有变量int8_t的值为 1110,1101(即十进制的 -30),那么赋值给int16_t的变量的结果变成了 1111,1111,1110,1101.
另外还需要注意的是: 在计算表达式的值的时候,在任何计算发生之前,会把变量的值增加到 “本机” (int)大小。比如 把两个short类型的变量相加结果会是int类型,如果是 有符号类型的时候我们需要特别的注意.