3

我想从 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

问题是我得到的毫秒值是负数。这个片段有什么问题?

4

1 回答 1

6

假设您确实正确初始化time了,那是因为乘以time->tv_sec1000 时溢出。在您的情况下,它已经是 14 亿,而您正在执行的有符号乘法最终溢出 21 亿左右。使用 64 位乘法来解决它:

uint64_t millis = (time->tv_sec * (uint64_t)1000) + (time->tv_usec / 1000);

确保使用合理的格式打印出来。

于 2013-09-06T04:55:27.567 回答