ubuntu c++时间计算

这是一个C++程序,用于测量代码段的执行时间。通过`gettimeofday`函数获取时间戳来计算时间差,提供了一个简单的性能分析工具。
#include <stdio.h>
#include <sys/time.h>
#include <unistd.h>
class Time
{
public:
    Time(){}
    ~Time(){}

    void start()
    {
        gettimeofday(&tv1,nullptr);
    }

    int cost()
    {
        gettimeofday(&tv2,nullptr);
        return (1000000*(tv2.tv_sec - tv1.tv_sec) + (tv2.tv_usec - tv1.tv_usec));
    }
private:
    struct timeval tv1, tv2;
};

int main()
{
    Time time;
    time.start();
    // do
    
    printf("cost time is %dus\n", time.cost());
    
    return 0;
}

Ubuntu系统中,C++实现睡眠功能有多种方法,以下是一些常用的方式: #### 使用 `usleep` 函数 `usleep` 函数可以使程序暂停执行指定的微秒数。需要包含 `<unistd.h>` 头文件。示例代码如下: ```cpp #include <iostream> #include <unistd.h> int main() { std::cout << "nitrate"; std::cout << std::flush; usleep(1000000); // 暂停1000000微秒,即1秒 std::cout << "firtilizers"; return 0; } ``` 在上述代码中,`usleep(1000000)` 会使程序暂停1秒后再继续执行后续代码[^1]。 #### 使用 `std::this_thread::sleep_for` 这是C++11标准库引入的方法,需要包含 `<thread>` 和 `<chrono>` 头文件。示例代码如下: ```cpp #include <iostream> #include <thread> #include <chrono> int main() { std::cout << "Starting sleep..." << std::endl; std::this_thread::sleep_for(std::chrono::seconds(2)); // 暂停2秒 std::cout << "Sleep finished." << std::endl; return 0; } ``` 此代码中,`std::this_thread::sleep_for(std::chrono::seconds(2))` 让当前线程暂停2秒。不过在编译 OpenCV 4.5.0 的 `gapi_async_test.cpp` 文件时,使用该函数可能会因缺少必要的头文件或者编译器标准设置不正确而无法识别[^2]。 #### 使用 `std::this_thread::sleep_until` 同样是C++11标准库的方法,`std::this_thread::sleep_until` 可以让线程休眠到指定的时间点。示例代码如下: ```cpp #include <iostream> #include <thread> #include <chrono> int main() { auto wake_time = std::chrono::steady_clock::now() + std::chrono::seconds(3); std::cout << "Going to sleep..." << std::endl; std::this_thread::sleep_until(wake_time); std::cout << "Woke up." << std::endl; return 0; } ``` 这里先计算出唤醒时间 `wake_time`,然后使用 `std::this_thread::sleep_until` 让线程休眠到该时间点。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值