函数的原型ctime
是
char *ctime(const time_t *timep);
正如我们所见,它返回一个字符串。但是,刺痛在哪里?
以及为什么我们不应该释放字符串的内存
这是示例代码会收到很多错误消息
char *p;
p = ctime(...);
...
free(p);
*** 检测到 glibc *** ./a.out: free(): 无效指针:0x00007f0b365b4e60 ***
函数的原型ctime
是
char *ctime(const time_t *timep);
正如我们所见,它返回一个字符串。但是,刺痛在哪里?
以及为什么我们不应该释放字符串的内存
这是示例代码会收到很多错误消息
char *p;
p = ctime(...);
...
free(p);
*** 检测到 glibc *** ./a.out: free(): 无效指针:0x00007f0b365b4e60 ***
它返回一个指向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()
只有,否则行为未定义。
它指向静态数据并且没有 malloc'd。