请看下面这段代码:
#include
#include
int main()
{
char a[1000];
int i;
for(i=0;
i<1000;
i++)
{
a[i]=-10-i;
}
printf("%d\n",strlen(a));
printf("%d\n",i);
printf("%d\n",a[i]);
return 0;
}
【C语言|陷阱之有符号无符号字符型数组】关于这3个答案,我相信没几个人能答得出来,下面我来公布一下正确答案:
246
1000
-24
是不是和我说的一样呢?
下面我来解释一下为什么是这3个答案。
首先是第一个246,为什么不是255或者1000呢?
因为定义的是char型数组,所以最多只能有255个数组元素,去掉字符‘0’,也就是‘\0’,但是为什么不是255呢?因为是从-10-i,i = 0开始就行的,定义的char型数组是有符号的,从-10减到-128,然后变成了127,这是由于负数的补码所致,可以查阅相关的资料。再从127减到0结束,总共有118-10+1+127-0+1=247个字符,但是strlen计算时‘\0’不能算在其中,所以只有246个字符。
第二个1000也是由于补码所致,不是你们所理解的存满了255个元素就退出循环了。
第三个-24这个值其实是这从i = 0到i = 999中的一个随机的a[i],这是由编译器决定的,因为此时的i = 1000,数组已经越界了。
推荐阅读
- C语言学习|第十一届蓝桥杯省赛 大学B组 C/C++ 第一场
- 【C】题目|【C语言】题集 of ⑥
- 单片机|自学单片机好找工作吗(会单片机能找什么工作?)
- 单片机|keil把源代码生成lib的方法
- c语言|一文搞懂栈(stack)、堆(heap)、单片机裸机内存管理malloc
- c语言|C语言初期学习遇到的特殊点 【三子棋详解】【初学者福音,详细总结,复习能手】
- 笔记|C语言数据结构——二叉树的顺序存储和二叉树的遍历
- 个人理解|【C语言基础之类型转换】
- c语言|【C语言】自定义类型 结构体 枚举 联合
- 学习分享|【C语言函数基础】