函数ctime的原型是
ctime
char *ctime(const time_t *timep);
字符串正如我们所看到的,它返回一个字符串。但是,在哪里包含刺?以及为什么我们不应该释放字符串的内存这是示例代码将得到大量的错误消息
char *p; p = ctime(...); ... free(p);
型
wpx232ag1#
它返回一个指向static缓冲区的指针,并且不能是free() d。来自man ctime:四个函数asctime()、ctime()、gmtime()和localtime()返回指向静态数据的指针,因此不是线程安全的。C99标准第7.23.3.2节ctime函数 * 指出调用ctime(timer)函数等效于asctime(localtime(timer)),而asctime()实现(如同一文档所示)等效于:
static
free()
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()
calloc()
realloc()
bxgwgixi2#
它指向静态数据,没有被malloc。
pbpqsu0x3#
您的指针p没有动态分配malloc或calloc,所以您没有要求heap memory为freed。你的p只是一个普通的指针,指向一些以前分配的内存(所以对你来说可用)。你给予给ctime()的变量应该在其他地方创建,该变量的创建者是借用给你的指针p的资源的所有者,所以你的指针只是一个observer,而不是一个resource owner,所以没有什么可以从你的指针中释放出来。
p
malloc
calloc
heap memory
freed
ctime()
observer
resource owner
3条答案
按热度按时间wpx232ag1#
它返回一个指向
static
缓冲区的指针,并且不能是free()
d。来自man ctime:四个函数asctime()、ctime()、gmtime()和localtime()返回指向静态数据的指针,因此不是线程安全的。
C99标准第7.23.3.2节ctime函数 * 指出调用
ctime(timer)
函数等效于asctime(localtime(timer))
,而asctime()
实现(如同一文档所示)等效于:字符串
传递给
free()
的参数必须是通过调用malloc()
、calloc()
或realloc()
返回的指针,否则行为未定义。bxgwgixi2#
它指向静态数据,没有被malloc。
pbpqsu0x3#
您的指针
p
没有动态分配malloc
或calloc
,所以您没有要求heap memory
为freed
。你的
p
只是一个普通的指针,指向一些以前分配的内存(所以对你来说可用)。你给予给
ctime()
的变量应该在其他地方创建,该变量的创建者是借用给你的指针p
的资源的所有者,所以你的指针只是一个observer
,而不是一个resource owner
,所以没有什么可以从你的指针中释放出来。