求下面代码的运行结果:
#include<stdio.h>
#include<stdio.h>
int main()
{
char arr[1000];
int i = 0;
for (i = 0; i < 1000; i++)
{
arr[i] = -1 - i;
}
printf("%d\n", strlen(arr));
return 0;
}
错误答案:1000
答案:255
原因:
易知代码是将-1、-2、-3、... 、-1000逐个装入数组arr中,但是应当注意数组的类型是char(字符数组),而char的数值存储范围是-128~127,因此-128以后的数字装入数组中时会发生某些改变。当i = 128时,计算 -1 - 128 (此时编译器会默认数字的类型为int型),-1的补码为11111111111111111111111111111111,128的补码为00000000000000000000000010000000,它们相加得00000000000000000000000001111111,这是一个正数,原反补相同,转换为十进制是127。同理,接下来是126、125 、 124 ...... 、1 、0 、-1、-2 、-3........,根据ASCLL表可知,ASCLL码值0对应的字符是 ‘\0’,当函数strlen读取到0时就会停止,1~128~0 总共255个数(0不计在内),因此最终的输出结果是255。
注:
(1)数字在没有存储到明确类型的变量中的时,一般默认是int型。
(2)计算机进行计算时,均以补码的形式进行。
(3)-1-128,计算机不能进行减法,所以应当看作-1 + 128的补码(不是-128的补码)。详见博文:浅析原码反码补码_喝亡黄的博客-CSDN博客