[c/c++]——数据的存储

22 篇文章 2 订阅

1.数据在内存中的存储

1.1 源码,反码,补码

源码: 直接将二进制按照正负数的形式翻译成二进制就可以
反码:将原码的符号位不变,其他位依次按位取反就可以得到
补码:在反码的基础上加一

ps:在内存中,数据存放的都是补码,因为计算机只有加法器

1.2机器的大小端(重点)

在这里插入图片描述
由图可知数据在(vs2008)图中是倒着存的,这就是机器的大小端问题

1.2.1什么是机器的大小端

大端模式存储:数据的低位字节序存储在高地址,数据的高位字节序存储在低地址
小端模式存储:数据的低位字节序存储在低地址,数据的高位字节序存储在高地址

1.2.2为什么要有大小端之分

原因:
C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如果将多个字节安排的问题

1.2.3怎么判断机器的大小端

      百度2015年系统工程师笔试题:

请简述大端字节序和小端字节序的概念,设计一个小程序来判断当前机器的字节序

方法一:强制类型转换一个int型

int CheckSystem()
{
	int a = 1;
	return (char)a;//*(char*)&a
}

方法二:联合体

int CheckSystem()
{
	union A
	{
	int i;
	char c;
	};
	A a;
	a.i = 1;
	return a.c;
}

只要返回值为1就是小端存储,为什么呢?请看下图
在这里插入图片描述

2.经典的数据存储笔试题

int main()
{
	char a = -1;
	signed char b = -1;
	unsigned char c = -1;
	printf("a=%d,b=%d,c=%d", a, b, c);
	system("pause");
	return 0;
}

答案:1,1,255.

c存到内存中为11111111(char只可以存8个比特位),无符号的整形提升相当于给前面补了24个0,然后直接输出就是255

#include <stdio.h>
int main()
{
    char a = -128;
    printf("%u\n",a);
    return 0;
}

答案:4294967168

存到内存中为10000000,因为是一个有符号的数,所以整形提升相当于给前面补24个1,直接按%u形式打印不考虑原反补,所以输出一个很大的数字

#include <stdio.h>
int main()
{
    char a = 128;
    printf("%u\n",a);
    return 0;
}

答案:4294967168

与上题相同,存到内存中的数字是一样的

int i= -20;
unsigned  int  j = 10;
printf("%d\n", i+j);

答案:-10

将俩个数字全部转换为补码进行运算

unsigned int i;
for(i = 9; i >= 0; i--)
{
    printf("%u\n",i);
}

答案:输出9-0后死循环

因为以%u打印不可能小于零

int main()
{
    char a[1000];
    int i;
    for(i=0; i<1000; i++)
   {
        a[i] = -1-i;
   }
    printf("%d",strlen(a));
    return 0;
}

在这里插入图片描述
7.

short num = 32767;
short int a = num +1;
printf("%d\n",a);
//0111 1111 1111 1111 -> 1000 0000 0000 0000
//(系统直接识别为最小值,不进行解码)

答案:-32768

举个栗子,char a = 128实际上就是-128

3.浮点数在内存中存储(了解)

举个栗子:

int a = -5.5//a在内存中是怎么存的?

写出他的二进制序列?

10000000000000000000000000101.1

实际上浮点数是这样存的

将a写成浮点数为:-101.1

写成科学计数法的形式:-1.011*2^2

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值