相信大多数学习C语言同学都对把指针作为函数参数的方法有一定的了解,今天课课家笔者为大家介绍指针的另一个用法-将指针作为函数的返回值。那么到底要怎样做才能将指针作为函数的返回值呢?下面由笔者给大家慢慢道来。
在C语言中,由于允许函数的返回值是一个指针(地址),所以我们将这样的函数称为指针函数。下面的代码例子定义了一个函数strlong(),用来返回两个字符串中较长的一个:
#include
#include
char*strlong(char*str1,char*str2){
if(strlen(str1)>=strlen(str2)){
returnstr1;
}else{
returnstr2;
}
}
intmain(){
charstr1[30],str2[30],*str;
gets(str1);
gets(str2);
str=strlong(str1,str2);
printf("Longerstring:%s\\n",str);
return0;
}
输出结果:
CLanguage↙
www.kokojia.com↙
Longerstring:www.kokojia.com
用指针作为函数返回值时需要我们注意的一点是:函数运行结束后会销毁在它内部定义的所有局部数据,包括局部变量、局部数组和形式参数,函数返回的指针我们尽量不要指向这些数据,因为C语言没有任何机制来保证这些数据会一直有效,它们在后续使用过程中可能会引发运行时错误,具体大家可以观察下面的代码例子:
#include
int*func(){
intn=100;
return&n;
}
intmain(){
int*p=func(),n;
n=*p;
printf("value=%d\\n",n);
return0;
}
输出结果:
value=100
n是func()内部的局部变量,func()返回了指向n的指针,根据上面的观点,func()运行结束后n将被销毁,使用*p应该获取不到n的值。但是我们从输出结果来看,func()运行结束后*p依然可以获取局部变量n的值,为了进一步看清问题的本质,笔者将上面的代码稍作修改,在第9~10行之间增加一个函数调用,具体代码如下:
#include
int*func(){
intn=100;
return&n;
}
intmain(){
int*p=func(),n;
printf("www.kokojia.com\\n");
n=*p;
printf("value=%d\\n",n);
return0;
}
输出结果:
www.kokojia.com
value=-2
从修改后的输出结果我们可以看到,现在p指向的数据已经不是原来n的值了,它变成了一个毫无意义的甚至有些奇怪的值。与前面的代码相比,该段代码仅仅是在*p之前增加了一个函数调用,这一细节的不同却导致输出结果有天壤之别,或许有同学会问个中的原理到底是什么呢?前面我们说函数运行结束后会销毁所有的局部数据这个观点并没错,大部分C语言教材也都强调了这一点。但是,这里所谓的销毁并不是将局部数据所占用的内存全部抹掉,而是程序放弃对它的使用权限,弃之不理,后面的代码可以随意使用这块内存。对于上面的两个例子,func()运行结束后n的内存依然保持原样,值还是100,如果使用及时也能够得到正确的数据,如果有其它函数被调用就会覆盖这块内存,得到的数据就失去了意义。第一个例子在调用其他函数之前使用*p抢先获得了n的值并将它保存起来,第二个例子是在有其他函数被调用后才使用*p获取数据,这个时候内存已经被后来的函数覆盖了,而覆盖它的究竟是一份什么样的数据我们无从推断(一般是一个没有意义甚至有些奇怪的值)。
本次利用指针作为函数返回值的讲解到此暂告一段落,如果以后有什么补充或修改的话笔者会在此进行补充或者修改,同时也欢迎大家对本次的讲解提出建议和补充。最后希望本次的讲解能对大家学习C语言起到一个帮助的作用!
上一篇:简单分析C语言位运算
¥299.00
¥399.00
¥29.00
¥498.00