一道真题(数据在内存中的存储)

本文通过两道题目详细分析了C语言中字符数组在内存中的存储和赋值过程中可能出现的截断现象,特别是涉及负数、补码以及整型提升时的情况。第一题解释了如何通过截断计算出字符串长度为255。第二题讨论了一个因整型提升和无符号类型导致的死循环问题。

有这么一串代码:

int main(){
	char a[1000];
	int i;
	for(i = 0; i < 1000; i++){

		a[i] = -1 - i;

	}
	printf("%d\n", strlen(a));
	
	return 0;
}

问:打印的结果是多少
分析过程如下:

  1. 首先我们要知道c语言中,字符串是使用字符数组的方式表示
  2. 字符串是一种特殊的字符数组,以‘\0’结尾
  3. char a[1000],a本来在初始化的时候,不是字符串,不能用函数strlen对其进行操作
  4. 这个循环就是在这个数组的每个元素赋值,如果某个位置赋值为‘\0’,那么这个数组即完成赋值,并且可以进行操作
  5. a[i] = -1 - i;,看似给每个元素赋值 -1,-2,-3,-4,但是其中有这么个小陷阱,-1-i是int类型,int类型在赋值给char类型,这个过程就会发生截断
  6. 负数在内存中的存储是以补码的形式存储,例如-1//1111 1111 1111 1111 1111 1111 1111 1111 char类型(32位下)是一个字节,发生截断//1111 1111
  7. 我们知道有某个位置被赋值给’\0’(ascii码的值为0) ,数组即完成赋值,又根据第六条和循环条件,我们可以判断出这个数截断前//1111 1111 1111 1111 1111 1111 0000 0000(注意这个数是补码),此二进制在十进制下即为-256,所以在第256个位置被赋予了’\0’,此字符串的长度为255。
    我们来检验一下
    在这里插入图片描述

第二题

让我们来看一下如下代码

int main(){
	
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值