例:計算時間戳
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;