在计算机的世界里,只有0和1,也就是二进制。
我们如何把一个十进制的数转成二进制或者其他进制,其实还是很简单的,看下面这张图
十进制转二进制
十进制的123转成二进制就是1111011,转成几进制都是一个道理。
一、二进制
1.1 二进制是计算机采用的表示数字的方式, 每个数位上只有0和1;
1.2 任何整数一定可以采用二进制的方式表示, 小数的二进制这里不多说;
1.3 字节内部采用二进制方式记录数字, 一个字节分成八段, 每个分段有一个编号, 最右边分段编号是0, 向左逐渐递增
1.4 相邻分段之间有2倍关系, 某个分段的数字相当于2的编号次方, 如图:
二进制转十进制:
把每个数位单独转换后把所有的转换结果求和
例:01001110 = 2^6 2^3 2^2 2^1 = 64 8 4 2 = 78
十进制转二进制:
方法一:(不适用于处理大数字)先把十进制数字拆分成多个2的整数次方之和, 然后对每个结果单独转换, 最后其他数位补0。
59 = 32 16 8 2 1 = 2^5 2^4 2^3 2^1 2^0 = 00111011
方法二:除2取余, 逆序余数;
上述两种方法算出来的是二进制原码
计算机字节里采用二进制补码记录数字
所有非负数整数, 补码和原码一样
二、八进制
2.1 把二进制表示方式的所有数位从右向左每三个数位分成一组, 每组用一个0到7之间的数字代替可得到八进制表示方式
2.2 每三个数位可以采用421方法把二进制转化成八进制
2.3 可以在程序中使用八进制表示数字, 为了避免与十进制混淆, 需要在八进制前面加0(零)
2.4 %o可以作为八进制数的占位符
结果:
152 106
152 152
三、十六进制
3.1 所有数位从右向左每四个数位分成一组, 每组用一个字母替换就得到对应的十六进制表示方式, 先把每组转换成十进制, 转换结果如果在0到9之间则用阿拉伯数字字符替换, 否则用‘a’到'f'这六个英文字母替换
3.2 每四个数位可以采用8421方法把二进制转化成十六进制
3.2 可以在程序中使用十六进制表示数字, 但是必须以0x做开头
3.3 %x %X 可以作为十六进制数的占位符(%x输出a-f, %X输出A-F)
结果:
0xab 0XAB
练习: 十进制转二进制
四、负数的二进制
4.1 先计算出相反非负数的二进制
4.2 把第一步的计算结果每个数位变成相反内容, 然后再加一
求:-5的二进制:
5: 0000 0101
取反: 1111 1010 1
-5: 1111 1011
4.3 上述方法算出来的是二进制补码, 可以直接记录在字节中
4.4 有符号的二进制补码中最左边的数位叫做符号位, 符号位是0表示正, 1表示负, 且符号位不能等同与正负号
4.5 当把一个占地大的整数类型数据赋值给占地小的整数类型存储区时只会保留部分二进制数据, 因此导致十进制表示方式发生变化。
4.6 当把一个占地小的整数赋值给占地大的整数类型存储区时要扩充二进制数位, 在有符号位的情况下扩充出来的二进制里全是符号位的数值, 无符号数据填充0;
结果:
ch = 44
num = 44
分析:300是整数占四个字节, 用二进制表示如下(ps: 只保留最右边的)
00000000 00000000 00000001 00101100
练习:计算下面的结果(结果在下方)
结果:
ch = -56
num = -56
小伙伴们掌握了吗?一定要多多的练习哦~这样二进制的题目那是手到擒来!
问:下面结构体的定义语句中,错误的是( )。
A) struct ord {int x;int y;int z;} struct ord a;
B) struct ord {int x;int y;int z;}; struct ord a;
C) struct ord {int x;int y;int z;} a;
D) struct {int x;int y;int z;} a;