ctime()返回一个字符串,为什么我们不需要free()这个字符串的内存?

thl*_*ood 8 c string memory-management heap-memory stack-memory

功能的原型ctime

char *ctime(const time_t *timep);
Run Code Online (Sandbox Code Playgroud)

我们可以看到,它返回一个字符串.但是,哪里有刺痛?

为什么我们不应该释放字符串的内存

这是示例代码将获得大量错误消息

char *p;
p = ctime(...);
...
free(p);
Run Code Online (Sandbox Code Playgroud)

***glibc检测到***./a.out:free():指针无效:0x00007f0b365b4e60***

hmj*_*mjd 10

它返回一个指向static缓冲区的指针,不能为free()d.来自man ctime:

四个函数asctime(),ctime(),gmtime()和localtime()返回一个指向静态数据的指针,因此不是线程安全的.

C99标准,第7.23.3.2ctime函数声明调用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;
}
Run Code Online (Sandbox Code Playgroud)

传递的参数free()必须是指针由一个调用返回malloc(),calloc()realloc()只,否则该行为是不确定的.

  • 只需添加一个,如果你想要一个线程安全的版本,请使用ctime_r()代替. (5认同)