最近在敲代码的时候,又出现了一些莫名的错误,我竟然想返回整个字符串!C语言编译器还是有它自己的脾气的,不是你想返回什么就返回什么。
首先,我想说的是,没必要返回字符数组,真的(其实也不能返回整个字符串)。
如果你把要修改的字符串当作函数参数传递后,在函数内部对其进行修改就已经改变了它在主函数的值。因为传递数组,也可以看作指针传递。
其次,如果你不想把要修改的字符串当作函数参数来传递,那就直接开个全局变量,想在哪修改就在哪修改,完全不用考虑传递问题。
所以实在没必要用函数传递字符串,况且它也传递不了,最多传个指针(字符串首地址)意思一下。
最后,我想说很多时候数组名是可以被看作是一种“指针”,但最好是看作一种指针常量,其实最最好是不要把它当作指针,他就是数组的名字。归根结底,数组名和指针还是有区别的,并非完全等价。
下面是我的debug过程,不想看的直接略过。
错误代码:
#include <stdio.h>
char cal(char ch[])
{
return ch;
}
int main()
{
char ch[20];
scanf("%s",ch);
ch=cal(ch);
printf("%s",ch);
return 0;
}
[Error] invalid conversion from 'char*' to 'char' [-fpermissive]
[Error] incompatible types in assignment of 'char' to 'char [20]'
我想法是把一个字符串传到函数里后,经过一系列运算,再把它返回。但有两个问题,一是函数类型与返回值不符,二是不能对数组的地址进行修改。
正确代码如下(对比int数组顺便复习一下指针加减):
#include <stdio.h>
char* cal(char ch[])
{
ch[0]='b';
return ch;//这里的ch隐式转化为了指向字符串首地址的指针,所以函数类型要用char*
}
int *test(int a[])
{
a[0]=0;
return a;
}
int main()
{
int *fp;
int arr[20]={9,34,122,4532,3};
char ch[20],*p;
scanf("%s",ch);
p=cal(ch);
//ch=cal(ch);//为什么错了?因为数组名相当于指针常量,不能被修改
fp=test(arr);
printf("%d %d %d\n",*(fp),*(fp+1),*(fp)+1);
//注意最后一位是1,在0的基础上加1,因为fp+1并没有改变fp指向的地址。区分:fp+1与fp++;
printf("%s",p);//注意此处不是*(p),输出字符串参数就是指针。
return 0;
}
最后的最后,来一段正常人用的代码:
#include <stdio.h>
void cal(char ch[])
{
ch[0]='b';
}
int main()
{
char ch[20]="abc";
cal(ch);
printf("%s",ch);
return 0;
}