温馨提示×

c++ timeval如何计算时间差

c++
小樊
95
2024-12-05 00:23:17
栏目: 编程语言
C++开发者专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

在C++中,timeval结构体用于表示时间值,包括秒和微秒

#include <iostream>
#include <sys/time.h>

int main() {
    // 创建两个timeval结构体实例
    struct timeval t1, t2;

    // 获取当前时间(t1)和另一个时间点(t2)
    gettimeofday(&t1, NULL);
    // 假设t2是在某个事件发生后获取的
    gettimeofday(&t2, NULL);

    // 计算时间差(以微秒为单位)
    long usec_diff = t2.tv_usec - t1.tv_usec;
    long sec_diff = t2.tv_sec - t1.tv_sec;

    // 如果微秒差值为负数,则从秒差值中减去1,并将微秒差值加上1000000
    if (usec_diff < 0) {
        sec_diff -= 1;
        usec_diff += 1000000;
    }

    // 输出时间差(以秒和微秒为单位)
    std::cout << "Time difference: " << sec_diff << " seconds, " << usec_diff << " microseconds" << std::endl;

    return 0;
}

这个示例首先获取当前时间(t1)和另一个时间点(t2),然后计算它们之间的时间差(以微秒为单位)。如果微秒差值为负数,代码会将其调整为正数。最后,代码输出时间差(以秒和微秒为单位)。

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读:c++ timeval在实际项目中的应用

0