关于返回局部变量的内存
来源:互联网 发布:录像软件fraps 编辑:程序博客网 时间:2024/06/03 13:01
在C语言中,自动变量在堆栈中分配内存,当包含自动变量的函数或代码块退出时,它们所占用的内存便会被回收,为了能够在包含自动变量的函数或代码块退出时,仍然能够访问这些自动变量的内存,可以如下几种方案:
1)返回一个指向字符串常量的指针。如
char *func(){ return "only works for simple strings";}
仅适用于简单的情形。
2)使用全局声明的数组
这种方法是最简单的,但是缺点也是显而易见,因为任何人都有可能修改这个数组内容。
3)使用静态数组。
char *func()
{
static char buffer[20];
...
return buffer;
}
这样做的缺点是该函数下一次调用时会覆盖这个数组的内容,所以调用者必须备份数组里的内容。
4)显示分配内存,保存返回的值
char *func()
{
char *s=malloc(100);
...
return s;
}
这样做的缺点是,调用者很容易忘记释放内存,从而造成内存泄露。
好了,言归正传。inet_ntoa函数的输入参数是u_int型的ip地址,返回的却是指向ip字符串的指针,很明显,ip字符串所占的内存是在函数内部分配的,而我们并不需要释放该内存,所以,它分配的内存是静态的,也就是说下一次调用该函数时会覆盖这个数组的内容,所以就会出现上述的结果(printf里面的可变参数的求值是从右到左的)。为了解决这个问题,我们只需备份数组里的内容即可。
1)返回一个指向字符串常量的指针。如
char *func(){ return "only works for simple strings";}
仅适用于简单的情形。
2)使用全局声明的数组
这种方法是最简单的,但是缺点也是显而易见,因为任何人都有可能修改这个数组内容。
3)使用静态数组。
char *func()
{
static char buffer[20];
...
return buffer;
}
这样做的缺点是该函数下一次调用时会覆盖这个数组的内容,所以调用者必须备份数组里的内容。
4)显示分配内存,保存返回的值
char *func()
{
char *s=malloc(100);
...
return s;
}
这样做的缺点是,调用者很容易忘记释放内存,从而造成内存泄露。
好了,言归正传。inet_ntoa函数的输入参数是u_int型的ip地址,返回的却是指向ip字符串的指针,很明显,ip字符串所占的内存是在函数内部分配的,而我们并不需要释放该内存,所以,它分配的内存是静态的,也就是说下一次调用该函数时会覆盖这个数组的内容,所以就会出现上述的结果(printf里面的可变参数的求值是从右到左的)。为了解决这个问题,我们只需备份数组里的内容即可。
0 0
- 关于返回局部变量的内存
- 关于函数返回局部变量的内存细节知识
- 关于返回局部变量的
- 关于函数返回局部变量的问题
- 局部变量的返回
- 关于函数返回局部变量
- 栈内存的临时性不能返回局部变量地址
- 内存与对于返回局部指针变量的思考
- 关于局部指针变量和数组的操作返回值
- 关于 C++ 函数返回局部变量的警告
- 关于返回局部变量的指针或引用
- c语言中关于局部变量的返回值
- 返回局部变量的问题
- 返回局部变量的问题
- 返回局部变量的问题
- 返回局部变量的地址
- 返回局部变量的问题
- 返回局部变量的引用
- webService的用法简介
- 矩阵有关知识的深刻理解!
- JS性能优化详细
- Android通用流行框架大全
- ImageView中ScaleType
- 关于返回局部变量的内存
- java学习、java教程:5种Java数据计算层的解决方法
- 七种可视化python工具
- 成功的秘诀
- JVM理解其实并不难!
- 比较String[i].charAt(j)与char[i][j]的运行时间
- LCA问题
- C程序的基础系统代码
- 关于Eclipse 自动重写某父类或者接口的方法@override