一:分析如下代码
本意为将整数转化成字符数组存储,然后将这个字符数组返回。经艰苦实践,发现不能,原因是指针s是局部变量,当函数返回时s即销毁,当然不会返回成功了,只能把一个无意义的地址传回去。
当然这样就需要传进一个s了。当然会后指针s的生命周期尚未结束,故不会出错。值得总结。
二:读以下代码
这段代码编译通过,运行就有问题了,想用指针对字符串做处理,可以先定义好字符数组,然后再用指针。也就是必须出现char s[const]这样的声明之后才可用指针访问使用。
三:代码如下
不注释的时候发现输出尾部总混有str1的成分,这是为什么呢?原因是我们声明str2是以字符数组,而用字符数组处理字符串时,最为重要的问题就是结束符'\0'。如果不告诉str2结束部分,那么输出的时候,str2就会一直往后查直到发现'\0'.可是最后却找到的是str1的'\0'.越界了。所以字符串虽然可以用字符数组来处理,但还是有所不同的。万分注意。
char* toStr(int num)
{
char s[100];
int i = 0;
while(num > 0)
{
s[i++] = num % 10 + '0';//记住为什么+'0'
num /= 10;
}
s[i] = '\0';
return s;
}
本意为将整数转化成字符数组存储,然后将这个字符数组返回。经艰苦实践,发现不能,原因是指针s是局部变量,当函数返回时s即销毁,当然不会返回成功了,只能把一个无意义的地址传回去。
所以正确的处理方法可以这样。
void toStr(int num, char *s)
{
int i = 0;
while(num > 0)
{
s[i++] = num % 10 + '0';
num /= 10;
}
s[i] = '\0';
}
当然这样就需要传进一个s了。当然会后指针s的生命周期尚未结束,故不会出错。值得总结。
二:读以下代码
char *s;
{
//这里面是对s[i]的访问和处理
}
这段代码编译通过,运行就有问题了,想用指针对字符串做处理,可以先定义好字符数组,然后再用指针。也就是必须出现char s[const]这样的声明之后才可用指针访问使用。
三:代码如下
#include<iostream>
using namespace std;
char *ch(char *str1, char *str2)
{
char *p;
p = str2;
while(*str1 != NULL)
{
*str2 = *str1;
str1++;
str2++;
};
*str2 = '\0';
return p;
}
int main()
{
char str1[]="I am glad to meet you!";
char str2[50];
cout << str2 << endl;
cout << ch(str1, str2) << endl;
cout << str2 << endl;
return 0;
}
在第14行注释与不注释的情况下,进行测试。
不注释的时候发现输出尾部总混有str1的成分,这是为什么呢?原因是我们声明str2是以字符数组,而用字符数组处理字符串时,最为重要的问题就是结束符'\0'。如果不告诉str2结束部分,那么输出的时候,str2就会一直往后查直到发现'\0'.可是最后却找到的是str1的'\0'.越界了。所以字符串虽然可以用字符数组来处理,但还是有所不同的。万分注意。