下面看一个例子:
#include<iostream>
using namespace std;
int main()
{
char ch[3000];
int i;
for(i=0;i<3000;i++)
{
ch[i]=-1-i;
}
cout<<strlen(ch)<<endl;
while(1);
return 0;
}
输出:
分析:
strlen()遇到\0就会结束,所以判断这个数组中何时出现\0;
由于-1-i的数据类型为int,int到char会发生数据的截断,接下来判断的是,在什么时候,数据的截断会造成数据的丢失,这就是问题的关键。
举个简单的例子:
把八位的二进制数赋值给四位的二进制数,比如:
0000=0000 0011
0000=0000 0111
0000=0000 1111
…像这些都不会造成数据的丢失,但是如果这样:
0000=0001 0000,这样四位的二进制数保存的就为0000,而那个1就没有保存下来。
回到题目,char是8位,int是32位,类比例子:
char[255]=000… 01 0000 0000,只能保存前面那8个0,此时就发生了数据的到丢失。
接下来:char[256]=000…01 1111 1111对于前面那 8位,相当于从头开始。
所以strlen()遇到\0是在char[255]的位置,所以答案就为:char[0]-char[254],总共255个。