如何使用timeval结构计算毫秒数?

时间:2013-09-06 04:44:43

标签: gcc timeval

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

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

1 个答案:

答案 0 :(得分:6)

假设你正确地初始化了time,那是因为当你将time->tv_sec乘以1000时你会溢出。在你的情况下,它已经是14亿,而你所做的有符号乘法最终会溢出在21亿左右。使用64位乘法来解决它:

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

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