C语言计算函数执行时间


使用time()测量秒数

#include <stdio.h>
#include <time.h>

int main() {
    // 获取操作前的当前时间
    time_t start_time = time(NULL);

    // 执行一些操作(例如,一个简单的循环)
    for (long i = 0; i < 1000000000; ++i);

    // 获取操作后的当前时间
    time_t end_time = time(NULL);

    // 计算时间差
    double duration = difftime(end_time, start_time);

    // 打印时间差
    printf("花费的时间: %.2f 秒\n", duration);

    return 0;
}

花费的时间: 3.00 秒


使用clock()测量更高精度的时间

#include <stdio.h>
#include <time.h>

int main() {
    // 获取操作前的当前时钟时间
    clock_t start_time = clock();

    // 执行一些操作(例如,一个简单的循环)
    for (long i = 0; i < 1000000000; ++i);

    // 获取操作后的当前时钟时间
    clock_t end_time = clock();

    // 计算时间差
    double duration = (double)(end_time - start_time) / CLOCKS_PER_SEC;

    // 打印时间差
    printf("花费的时间: %.6f 秒\n", duration);

    return 0;
}

花费的时间: 2.500000 秒

CLOCKS_PER_SEC 是标准C的time.h头文件中宏定义的一个常数,表示一秒钟内CPU运行的时钟周期数,用于将clock()函数的结果转化为以秒为单位的量,但是这个量的具体值是与操作系统相关的。


使用gettimeofday()测量微秒级时间

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

int main() {
    struct timeval start, end;

    // 获取操作前的当前时间
    gettimeofday(&start, NULL);

    // 执行一些操作(例如,一个简单的循环)
    for (long i = 0; i < 1000000000; ++i);

    // 获取操作后的当前时间
    gettimeofday(&end, NULL);

    // 计算时间差
    double duration = (end.tv_sec - start.tv_sec) + (end.tv_usec - start.tv_usec) / 1e6;

    // 打印时间差
    printf("花费的时间: %.6f 秒\n", duration);

    return 0;
}

花费的时间: 2.499999 秒

注意事项

time(): 返回的秒数可能是整数,因此精度较低。
clock(): 提供的时间可能更精确,因为它是基于CPU时间。
gettimeofday(): 提供更高的时间精度,通常可以精确到微秒级。

实际的时间输出将根据系统性能和执行时间而有所不同。以上输出只是示例,用于说明代码的运行结果。


转载自公众号:一口Linux

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值