没有注意到原来localtime是非线程安全的函数,返回的是一个static的地址,当多线程调用时,如果调用后不及时使用,该内存地址可能会被覆盖,导致出错,我在实际使用过程中,已经及时调用了,由于线程数量过多(100个),仍然出现了问题,这个时候需要使用localtime_r这个版本进行转换,该函数线程安全。估计是在设计初期没有考虑到线程安全的问题,导致后来只能增加新的函数来进行区分操作。
char day[64] = {'\0'};
struct tm ptm = {0};
strftime(day, sizeof(day), "%Y%m%d", localtime_r(&day_time, &ptm));