今天随便写个小程序,就写了一个字符串连接的程序。接下来是我写的程序,可是问题却出现了,在主函数中不能把字符串打印出来。先看程序:
#include<stdio.h>
char* strcat(char*,char*);
int main()
{
char *str;
char str1[80] = "Hello world";
char str2[] = "I love you ";
str = strcat(str1,str2);
printf("%s\n", str);
return 0;
}
char* strcat(char* str1,char* str2)
{
char str[40];
int i = 0;
int j = 0;
while(str1[i] != '\0')
{
str[i] = str1[i];
i++;
}
str[i] = '\0';
while(str2[j] != '\0')
{
str[i] = str2[j];
j++;
i++;
}
str[i] = '\0';
printf("%s\n", str);
return str;
}
执行的结果如下:
在函数体中能够正确的打印,但主函数中打印的是乱码,后来经过调试,写出了如下的程序:
#include<stdio.h>
#include<malloc.h>
char* strcat(char*,char*);
int main()
{
char *str;
char str1[80] = "Hello world";
char str2[] = "I love you ";
str = strcat(str1,str2);
printf("%s\n", str);
free (str);
return 0;
}
char* strcat(char* str1,char* str2)
{
char *str;
str = (char*)malloc (40 * sizeof(char)) ;
int i = 0;
int j = 0;
while(str1[i] != '\0')
{
str[i] = str1[i];
i++;
}
str[i] = '\0';
while(str2[j] != '\0')
{
str[i] = str2[j];
j++;
i++;
}
str[i] = '\0';
printf("%s\n", str);
return str;
}
在这次打印中,程序执行出了正确的结果。
首先,为什么在第一次的程序中没能打印出正确的结果?
因为我们定义的str[40]是一个局部的变量,而首地址的指针str一个局部的变量,当函数执行完毕时,数组被销毁,当然首地址也被销毁,即返回了一个不存在的指针,在主函数中就打印出了乱码。当我们在函数中动态的分配一个内存的时候,上述的情况就不会出现了。
再者,为什么用free?
因为当我们动态的分配了一个内存,系统不会自动的销毁,必须由程序员自己来销毁,否则,就会造成内存的泄露。
最后,为什么在函数的参数列表的类型是char*? 即char* strcat(char*,char*);
因为数组的首地址是一个char *的,必须类型匹配。当然也可以再参数列表中传递数组,但实际还 是传递的指针。
对于程序员,特别是初学者,要不断的实践,不要想当然,要自己能够把程序敲出来。当然,思路清晰是很重要的。