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

sam*_*m18 3 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
Run Code Online (Sandbox Code Playgroud)

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

Car*_*rum 6

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

uint64_t millis = (time->tv_sec * (uint64_t)1000) + (time->tv_usec / 1000);
Run Code Online (Sandbox Code Playgroud)

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