例:计算时间戳
struct timeval t_start;
gettimeofday(&t_start, NULL);
int64_t ts_now = t_start.tv_sec * 1000 + t_start.tv_usec / 1000;
此外会发出32位数据溢出,因为t_start.tv_sec是long型,在32位设备上为4个字节,t_start.tv_sec为1970年开始的秒数,乘以1000会发生4字节溢出截断,导致获取时间戳异常。需改为:
ts_now = ((int64_t)t_start.tv_sec) * 1000 + ((int64_t)t_start.tv_usec) / 1000;