一、前言
这两天在复习计组第二章(数据的表示和运算),我快被这些破题搞吐了,你说很难吗?它也不难,它真的是那种很恶心的感觉。就你做一道浮点数让你转换成IEEE754你觉得还成,连着做30道真是想死的心无法阻挡。
于是我一怒之下就写了个函数,毕竟没有人比计算机更懂计算机,爷不算了,你直接告诉我你自己存的是个什么玩意!
二、代码
不跟你多bb,直接上代码了
#include <stdio.h>
#include <iostream>
using namespace std;
template <typename T>
void OutinBinary(T num) //将浮点数以二进制输出
{
unsigned char *p, ch;
int i;
p = (unsigned char *)(&num);
i = sizeof(num); //字节数,int、float为4字节即32位
cout << num << "占用" << i << "个字节" << endl;
cout << num << "在内存中形如:";
for (i = sizeof(num) - 1; i >= 0; i--)
{
ch = *(p + i);
for (int j = 0; j < 8; j++)
{
if ((ch << j) & 0x80)
putchar('1'); //0x80即128,二进制表示1000 0000,这里操作目的是取最高位
else
putchar('0');
}
putchar(' ');
}
cout << endl << endl;
}
原理很简单,对于每一个字节(注意大端存储),和1000 0000(0x80)做与运算即可获得最高位的数值,然后左移求下一位,直到当前字节结束,进入下一个字节循环。
调用的话,你可能需要写一个分支语句,来控制传入参数的类型,我给一个比较简单的例子:
int main()
{
while (true)
{
int choose;
printf("请选择要查看数的类型:\n");
printf("1.Int 2.Float 3.Double:\n");
scanf("%d", &choose);
switch (choose)
{
case 1:
int num1;
printf("请输入一个整型数,将以int型存储:");
scanf("%d", &num1);
OutinBinary(num1);
break;
default:
exit(0);
}
}
return 0;
}
三、运行结果
注:short是有符号的,因此65535全1,对应补码表示的数就是-1。你传参是unsigned short,那就会显示65535。
四、结语
写这个只是想记录一下,没准以后可以用来快速验算。学习还是要踏实,一天做不了30道就两天嘛,唉,啃啃这个硬骨头吧。