1、栈内存
看下面的例子:
//返回的是局部变量的地址,该地址位于动态数据区,栈里
char *GetMemory( void )
{
char p[] = "hello world";
return p;
}
void Test( void )
{
char *str = NULL;
str = GetMemory();
printf("%s/n", str);
}
这是一个错误的程序,编译时编译器会给出警告:
warning C4172: returning address of local variable or temporary
造成错误的原因是p是在栈上分配的内存,当调用函数GetMemory结束后,这个地址即被释放,这时这个地址存储的内容是未知的。
解决的一个办法就是在堆上或者静态存储区分配,所以有下面两者解决办法
2、堆内存分配
调用malloc分配即可,即
#include<string.h>
char *GetMemory( void )
{
char *p = (char*)malloc(sizeof(char)*100);
if(p == NULL)
return NULL;
strcpy(p, "hello world");
return p;
}
或者可以在静态存储区分配内存,加上static关键字即可
3、静态存储区分配
//返回的是静态局部变量的地址,该地址位于静态数据区
char *GetMemory( void )
{
static char p[] = "hello world";
return p;
}
这里再补充一种解决办法,常量字符串是位于内存的静态存储区的,所以这里可以这样修改:
4、定义指针,指向常量字符串
//返回的是字符串常量的地址,该地址位于静态数据区
char *GetMemory( void )
{
char *p = "hello world";
return p;
}
这里的指针p是常量字符串在静态存储区的地址,所以即使函数GetMemory退出了,但是只要程序未结束,这个静态存储区仍然存在。
另外,可以参考阅读:
http://blog.sina.com.cn/s/blog_596f35310100e3jm.html
http://blogold.chinaunix.net/u/16292/showart_665487.html