各种数据类型在内存中的存储内容

一、前言

这两天在复习计组第二章(数据的表示和运算),我快被这些破题搞吐了,你说很难吗?它也不难,它真的是那种很恶心的感觉。就你做一道浮点数让你转换成IEEE754你觉得还成,连着做30道真是想死的心无法阻挡。

于是我一怒之下就写了个函数,毕竟没有人比计算机更懂计算机,爷不算了,你直接告诉我你自己存的是个什么玩意!

二、代码

不跟你多bb,直接上代码了

#include 
#include 
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;
}

三、运行结果

各种数据类型在内存中的存储内容_第1张图片
注:short是有符号的,因此65535全1,对应补码表示的数就是-1。你传参是unsigned short,那就会显示65535。

四、结语

写这个只是想记录一下,没准以后可以用来快速验算。学习还是要踏实,一天做不了30道就两天嘛,唉,啃啃这个硬骨头吧。

你可能感兴趣的:(程序与算法,c++,编程语言,数据结构,计算机组成)