一点思考
函数返回指针
1、一种实现方式
char *inputSecond(void){
static char s[20]; //返回指针的函数,指向内容需要静态,才能保证指向内容不丢失
char *str=s; //指针一定要在定义的时候初始化,不然没机会初始化了
scanf("%s",str); //为s分配空间,并且用输入的内容给s赋值
return str;
}
2、第二种实现方式
char *inputSecond(void){
char *str=malloc((sizeof (char))*20);//分配20个字符的空间具有全局属性
scanf("%s",str);
return str;//返回指针,且刚刚分配的空间不会被销毁
}
3、反例
/*一个错误的示范*/
char *inputSecond(void){
char s[20]; //这部分内容属于该函数的
char *str=s;
scanf("%s",str);
return str;//返回给上一级函数的只有一个字符指针,而自己的s[20]会被销毁
}
指针作为形参
- 前提是:
int main(){
char b[20];
char *result=b; //指针指向数组
inputGetPointer(result);
}
void inputGetPointer(char *a){
scanf("%s",a);//为指向的内容(数组b)分配空间,并且用输入的字符串赋值
return;
}
反例:上一级函数无法获取字符数组
-
main:
- int main(){
char *result;//没有对应的数组空间
inputGetPointer(result);//错误示范
return 0;
}
- int main(){
/*一个错误的示范*/
void inputGetPointer(char *a){
char s[20];
char *str=s;
scanf("%s",s);
a=s;//a只能在定义的时候被赋值,错误
return;
}
数组名作为形参
void inputGetArray(char a[]){
scanf("%s",a);
//scanf可以给数组分配空间,直接影响到上一级函数的那个传形参a的数组
}
总结
1、 形参传递时:
传递的只是一个指针(如数组名,或指针,抑或是&a[0]的形式)
而这个指针指向的内容是属于调用该函数的上一级函数(如主函数)的。
2、C语言返回值只能是一个某某,不能是数组。
3、scanf函数会给数组分配空间,而不会给指针分配空间,指针分配空间可以使用上面提到的malloc。(因为数组的大小确定)
所以,像char *a; scanf(“%s”,a); 这样是不能操作的。
4、char a[20];只是声明有个数组,数组占这么大的空间,并没有为数组分配空间。
5、作为形参, char *a 和char a[] 实质上是一样的。
以上为实践心得,个人能力有限,有不正确和不妥的地方还请大家帮忙指正,谢谢~~