进制转换
我们目前接触到的进制有 二进制、八进制、十进制、十六进制
- 其他进制转十进制:
按权相加
- (1234) 10= 4 * 100+ 3 * 101+2 * 102+ 1 * 103
(0x1234) 16= 4 * 160+ 3 * 161+ 2 * 162+1 * 163
- 十进制 转 其他进制:
辗转相除法:将需要转换的数据不停的除以转换的进制数,直到商为0
- 十进制转二进制:
- 十进制转八进制:
- 八进制 转 十六进制:
借助于二进制,将八进制转换为二进制,将二进制转换为十六进制。
- 十六进制 转 八进制:
借助于二进制,将十六进制转换为二进制,将二进制转换为八进制。
有符号数和无符号数
在C语言中,整数是可以带符号的(有符号,signed)或不带符号的(无符号,unsigned)。这两种类型的整数在内存中以二进制形式表示。并使用不同的模式。
- 有符号数(Signed Numbers)
有符号数是来表示正数、负数、0的整数类型。在内存中,有符号数使用最高位(通常是符号位)来表示正负。如果最高位为0,表示这个数是正数或0,如果最高位为1,表示这个数是负数。其余位用于表示数值本身。
举例:例如一个8位有符号整数可以表示的范围是 -128 ~ 127 。这是因为1位用于表示符号(正或
负),剩下的7位
注意:有符号位是默认的,在C语言中,基本整数类型如int,short,long默认为有符号数,除非明确指定为无符号。
举例:
signed int num = 12; //标准有符号位写法
int num = 12; //默认省略signed关键字
- 无符号数(Unsigned Numbers)
无符号数是只能表示非负整数的数据类型。在内存中,无符号数不使用符号位,所有位都用于表示数值。因为,无符号数的范围比有符号数的范围更大。
注意:在C语言中,通过关键字后添加 unsignet 。来指定无符号类型,如 unsigned int、unsigned short…
举例:例如一个8位无符号整数可以表示的范围是 0 ~ 255 。这是因为所有8位都用来表示数值,没有符号位。
unsigned int num = 12; //标准无符号位写法
问题
1、什么是原码、反码、补码?
2、为什么要有这几个?
3、原码、反码、补码之间的转换关系。
解:
1、原码是一个数的二进制形式。反码是将原码中正数的符号位保持为0,负数的符号位保持为1,其余各位取反。补码是在反码的基础上再加1。
2、原码、反码、补码是为了在计算机中更好地表示正负数,简化加法和减法运算。
3、原码、反码、补码之间的转换关系如下:
-
对于正数,原码、反码、补码相同,即三码相等。
-
对于负数,反码是原码取反,补码是反码加1。
-
从补码转为原码,负数补码保持不变,正数补码也保持不变。
-
从原码或反码转为补码,正数原码、反码、补码相同,负数原码、反码取反后加1得到补码。