前言:
为了方便查看博客,特意申请了一个公众号,附上二维码,有兴趣的朋友可以关注,和我一起讨论学习,一起享受技术,一起成长。
1. return
return: 用来终止一个函数并返回后面跟的值。
使用:return (表达式);//() 可省略
注:
(1)C 不支持在函数外返回局部变量的地址,除非定义局部变量为 static 变量。
char *Func(void)
{
char buf[10];
......
return buf;//错误
}
buf 属于局部变量,位于栈内存中,在 Func 结束的时候被释放,故导致返回 buf 错误。
(2)函数可以返回局部变量的值,不涉及地址。
举例:
(1)
#include<stdio.h>
#include<stdlib.h>
char *Return_Test(void)
{
char *str = "return test";
return str;
}
int main(void)
{
char *pstr;
pstr = Return_Test();
printf("Return test is %s \r\n",pstr);
system("pause");
return 0;
}
因为字符串 char *str = “return test” 声明的是一个字符串常量,存储在只读数据段,声明的字符串指针仅是存放了只读数据段字符串的首地址,当程序结束退出时,存放该字符串的内存不会被收回。
(2)
#include<stdio.h>
#include<stdlib.h>
char *Return_Test(void)
{
char str[] = "return test";
return str;
}
int main(void)
{
char *pstr;
pstr = Return_Test();
printf("Return test is %s \r\n",pstr);
system("pause");
return 0;
}
因为 char str[] = “return test” 是一个局部变量,存储在栈中,当函数结束退出时,栈被清空,此时函数返回的是一个被释放的地址,测试结果为乱码,如下图:
上面的实现,如果加上 static 修饰(static char str[] = “return test”;),即可以的得到正确运行结果,实质是改变了变量的存储地址。数组的类似,因为数组名在编译器眼里,是局部变量的地址,返回一个地址等价于返回这个数组的指针,同样是涉及在栈去申请内存的问题。如果返回的是堆内存(用函数 malloc 申请的内存)的指针,则是可以的。malloc 申请的内存,用完了要及时释放(free),否则造成内存泄漏。
(3)
#include<stdio.h>
#include<stdlib.h>
char Return_Test(void)
{
char str = 'a';
return str;
}
int main(void)
{
char pstr;
pstr = Return_Test();
printf("Return test is %c \r\n",pstr);
system("pause");
return 0;
}
返回一个局部变量(静态/动态)的值是可以的,不涉及地址。
函数返回局部变量的值的可以的,但是涉及返回指针变量的时候,要注意函数执行结束后这一段内存是否还存在。注意定义:char *str = “Return test”; 与 char[] = “Return test”; 的区别,他们的存放空间是不一样的。