char * localized_time(char * filename)
{
struct tm *tm_ptr;
struct stat stat_block;
char buffer[120];
stat(filename,&stat_block);
tm_ptr = localtime(&stat_block.st_mtime);
strftime(buffer,sizeof(buffer),"%a %b %e %T %Y",tm_ptr);
return buffer;
}
问题就出在函数的最后一行,也就是返回buffer的那行。buffer是一个自动分配内存的数组,是该函数的局部变量。当控制流 离开申明自动变量的范围时,自动变量便自动失效。这就意味着即使返回一个指向局部变量的指针,当函数结束时,由于该变量已被销毁,谁也不知道这个指针所指向的地址的内容是什么。
在C语言中,自动变量在堆栈中分配内存。当包含自动变量的函数或代码块退出时,他们所占用的内存便被回收,他们的内容肯定会被下一个所调用的函数覆盖。这一切取决于堆栈中先前自动变量位于何处,活动函数申明了什么变量,写入了什么内容等。原先自动变量地址的内容可能被立即覆盖,也可能稍后才被覆盖。
解决这个问题有几种方案:
1、返回一个指向字符串常亮的指针;
2、使用全局申明的数组;
3、使用静态数组;
4、显示分配一些内存,保存返回的值(注意内存的释放)
5、调用者分配内存来保存函数的返回值。为了提高安全性,调用者应该同时指定缓冲区的大小。
如果可以在同一代码块中同时进行“malloc”和“free”操作,内存管理是最为轻松的