问题一:#include <iostream>
using namespace std;
char* pReturnErrorP()
{
char* p="I Love China!"; //改为char p[]="I Love China!";结果不变。
return p;
}
int main()
{
char* str=pReturnErrorP();
cout<<*str<<endl;
}
结果:
总结:
1:运行虽然不会出错,但是函数pReturnErrorP的设计概念却是错误的。因为pReturnErrorP内的“I Love China”是常量字符
串,位于静态存储区,它在程序生命期内恒定不变。无论什么时候调用pReturnErrorP,它返回的始终是同一个“只读”的内存块。
2:为什么是输出I,而不是乱码或者是I Love China!?这个还没弄懂。
问题二:
#include <iostream>
using namespace std;
int main()
{
char str[5]={'I','L','O','V','E'};
for(int i=0;str[i]!='\0';i++)
cout<<str[i];
cout<<endl;
}
结果:
总结:
最好将字符数组的长度定义的比有效长度至少大1。以免出错。
问题三:
#include <iostream>
using namespace std;
int main()
{
char str[5]="ILOVE";
cin>>str;
cout<<str<<endl;
return 1;
}
总结:
编译时:error C2117: 'ILOVE' : array bounds overflow。注意与问题二的不同。
问题四:
#include <iostream>
using namespace std;
int main()
{
char str[5]="ILOV";
cin>>str;
for(int i=0;str[i]!='\0';i++)
cout<<str[i];
cout<<endl;
return 1;
}
结果:
总结:
即使接收ILOVE的str数组大小只有5,但是会在E的下一个单元加‘\0’。所以以str[i]=='\0'为输出结束条件时,输出的仍然准确,是
ILOVE,而不是ILOVE后面加一些乱码。为了避免出错,我们还是将用于接收输入的字符数组大小定义的比我们输入的字符串大小最少多一个单位。