深度剖析数据在内存中存储

1、判断大小端问题

#include<stdio.h>
#include<windows.h>
int main()
{
	int x = 1;
	printf("%d\n", *((char*)&x));
	system("pause");
	return 0;
}

结果输出为1,说明为小端
在这里插入图片描述
如图所示,当输出为1时,说明其为小端,反之,则为大端。

2、

#include<stdio.h>
#include<windows.h>
int main()
{
	char a = -1;
	signed char b = -1;
	unsigned char c = -1;
	printf("%d %d %d\n", a, b, c);
	system("pause");
	return 0;
}

输出结果如下:

-1 -1 255
请按任意键继续. . .

首先a/b都是-1是显而易见的,那么c为什么是255呢?
a、b、c都定义为char类型,char只占一个字节,而最终打印要打印%d的形式,要占4个字节,对于ab,本身就是有符号整数,所以转换类型时,只需要在前面加24个1,最高位为1,表示有符号,其为补码,转换为源码时,结果为-1;而对于c来说,要转换为无符号数,前面需要添加24个0,表示源码,最终计算结果为255!特别提醒:整形提升的时候,要看自己的类型!!!

3、

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

输出如下:

a=4294967168 b=4294967168
请按任意键继续. . .

首先解释%u,表示无符号的十进制整数
a的二进制序列是1000 0000,要进行整形提升,符号位为1,则需要在前面加24个1,输出为2^32-128,就是打印出来的数字;b同理。

4、

#include<stdio.h>
#include<windows.h>

int main()
{
	int i = -20;
	unsigned j = 10;
	printf("%d\n", i + j);
	system("pause");
	return 0;
}

结果输出为:

-10
请按任意键继续. . .

分析如下:

//1000 0000 0000 0000 0000 0000 0001 0100 //-20的补码
//1000 0000 0000 0000 0000 0000 0001 0011 //-20的反码

//1111 1111 1111 1111 1111 1111 1110 1100 //-20的源码
//0000 0000 0000 0000 0000 0000 0000 1010 //10的源码
//----------------------------------------(相加)
//1111 1111 1111 1111 1111 1111 1111 0110
//符号位为1,则上述为补码形式,而%d打印有符号十进制整数,故需要转换为源码
//1111 1111 1111 1111 1111 1111 1111 0101(补码-1,转换为反码)
//1000 0000 0000 0000 0000 0000 0000 1010
//符号位不变,其余位按位取反,转换成十进制以后是-10

5、

#include<stdio.h>
#include<windows.h>

int main()
{
	unsigned int i = 10;
	for (i = 10; i >= 0; i--)
	{
		Sleep(500);
		printf("%u\n", i);
	}
	system("pause");
	return 0;
}

输出结果如下:

10
9
8
7
6
5
4
3
2
1
0
4294967295
4294967294
4294967293
4294967292
4294967291
4294967290
4294967289
4294967288

分析:
由于最开始i>=0,所以正常输出10……0,但是这个过程结束以后,由于打印%u即无符号十进制整数,-1的源码就是全1,转换过来以后就是第一个整数,依次类推,陷入死循环。

6、

#include<stdio.h>
#include<windows.h>

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

输出为:

255
请按任意键继续. . .

求字符串长度的本质:遇到‘\0’就停下来,本质就是0,计算长度不包含0.

#include<stdio.h>
#include<windows.h>
unsigned char i = 0;
int main()
{
	for (i = 0; i < 255; i++)
	{
		printf("hello world!\n");
	}
	system("pause");
	return 0;
}

结果:死循环
0-255,0-255这样子进行死循环。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值