函数ctime
的原型是
char *ctime(const time_t *timep);
正如我们所看到的,它返回一个字符串。但是,哪里有刺痛?
为什么我们不应该释放字符串的内存
这是示例代码将收到大量错误消息
char *p;
p = ctime(...);
...
free(p);
*** glibc检测到*** ./a.out:free():指针无效:0x00007f0b365b4e60 ***
答案 0 :(得分:10)
它返回指向static
缓冲区的指针,不能是free()
d。来自man ctime:
asctime(),ctime(),gmtime()和localtime()这四个函数返回一个指向静态数据的指针,因此不是线程安全的。
C99标准, 7.23.3.2节ctime函数表明调用ctime(timer)
函数等同于asctime(localtime(timer))
和asctime()
实现(如图所示)在同一文件中)相当于:
char *asctime(const struct tm *timeptr)
{
static const char wday_name[7][3] = {
"Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"
};
static const char mon_name[12][3] = {
"Jan", "Feb", "Mar", "Apr", "May", "Jun",
"Jul", "Aug", "Sep", "Oct", "Nov", "Dec"
};
static char result[26];
sprintf(result,
"%.3s %.3s%3d %.2d:%.2d:%.2d %d\n",
wday_name[timeptr->tm_wday],
mon_name[timeptr->tm_mon],
timeptr->tm_mday, timeptr->tm_hour,
timeptr->tm_min, timeptr->tm_sec,
1900 + timeptr->tm_year);
return result;
}
传递给free()
的参数必须是仅通过调用malloc()
,calloc()
或realloc()
返回的指针,否则行为未定义。
答案 1 :(得分:1)
它指向静态数据而不是malloc'd。