二进制打印介绍
C语言在格式化打印的时候有很多格式控制,比如十进制打印用%d输出,十六进制用%x输出,八进制用%o格式输出,但是当我们期望看一个数据的二进制的时候就必须借助计算器或者其他比较不方便于是考虑写一个简单的二进制打印函数。
二进制打印原理
计算机内部存储都是二进制的所以不管是有符号数还是无符号数都是二进制的,利用C语言的位操作就可以实现对每个位的访问,这里我仅仅是为了输出二进制,并不是要把这个数记录下来所以我打印的是2进制字符组成的字符串。
二进制打印代码
void printf_2(int data)
{
int i = 0;
for(i = 0;i<32;i++)
{
if(data&(0x80000000>>i))
{
printf("1");
}
else
{
printf("0");
}
}
printf("\r\n");
}
测试代码
printf("测试1:参数是十进制正数: %d\r\n",2147483647);
printf_2(2147483647);
printf("测试2:参数是十进制负数: %d\r\n",-1);
printf_2(-1);
printf("测试3:参数是十六进制数: 0x%X\r\n",0x80010000);
printf_2(0x80010000);
运行结果
结果解释说明
正数测试
有符号数的最高位是其符号位所以打印2147483647的结果最高位就是0;
十六进制数测试
负数测试
由于负数在计算机中是以补码的形式存在的所以-1打印结果是-1的补码
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)