我想从 timeval 类型的变量中检索以毫秒为单位的值。以下是我的尝试:
timeval* time;
long int millis = (time->tv_sec * 1000) + (time->tv_usec / 1000);
printf("Seconds : %ld, Millis : %ld", time->tv_sec, millis);
Output => Seconds : 1378441469, Millis : -243032358
问题是我得到负数的毫秒值。这个片段有什么问题?
假设您确实正确初始化了time
,这是因为在将time->tv_sec
乘以 1000 时溢出。 在你的例子中,它已经是 14 亿了,你正在做的符号乘法最终溢出了 21 亿左右。 使用 64 位乘法来解决它:
uint64_t millis = (time->tv_sec * (uint64_t)1000) + (time->tv_usec / 1000);
确保使用合理的格式打印出来。