当前位置: 首页 > 面试题库 >

在Linux中如何从C打印以毫秒和纳秒为单位的时差?

葛奇
2023-03-14
问题内容

我有这个程序可以打印2个不同实例之间的时间差,但是它以秒为单位打印。我想以毫秒为单位打印它,以纳秒为单位打印另一个。

//Prints in accuracy of seconds

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

int main(void)
{
    time_t now, later;
    double seconds;

    time(&now);
    sleep(2);

    time(&later);
    seconds = difftime(later, now);

    printf("%.f seconds difference", seconds);
}

我该怎么做?


问题答案:

首先阅读time(7)手册页。

然后,您可以使用clock_gettime(2) syscall(您可能需要链接-lrt才能获取它)。

所以你可以尝试

    struct timespec tstart={0,0}, tend={0,0};
    clock_gettime(CLOCK_MONOTONIC, &tstart);
    some_long_computation();
    clock_gettime(CLOCK_MONOTONIC, &tend);
    printf("some_long_computation took about %.5f seconds\n",
           ((double)tend.tv_sec + 1.0e-9*tend.tv_nsec) - 
           ((double)tstart.tv_sec + 1.0e-9*tstart.tv_nsec));

即使硬件计时器具有纳秒级的分辨率,也不要期望它们具有纳秒级的精度。并且不要尝试测量持续时间少于几毫秒的时间:硬件不够可靠。您可能还想使用clock_getres查询某些时钟的分辨率。



 类似资料:
  • 问题内容: 目前,我使用此代码 格式化时间。我需要加上毫秒,所以输出的格式为: 问题答案: 您可以使用 Boost的Posix Time 。 您可以用来从微秒分辨率的时钟获取当前时间: 然后,您可以计算当前日期的时间偏移量(由于持续时间的输出格式为,我假设它们是按当前日期偏移量计算的;如果不是,请随时为持续时间/时间间隔使用另一个 起点 ): 然后你可以使用,,访问器来得到相应的值。 不幸的是,似

  • 两个时间戳的示例 困难的部分原因是我认为没有类似的包来处理它。我不确定是否需要使用正则表达式来提取秒,然后将纳秒转换为毫秒。我愿意接受任何建议。 另外,您建议如何处理?我想我应该使用,然后像这样的包可以解析时间戳,甚至可以达到纳秒级的精度?

  • 问题内容: 这是我的代码: 是否可以在日期格式中添加毫秒和纳秒? 问题答案: 您可以通过在末尾添加来添加毫秒数,例如格式为。 毫微秒内没有参考。通常用于性能调试,而不用于显示目的。

  • 问题内容: 有什么办法可以使时间戳记中的毫秒数变为或(或出于好奇而使毫秒数)? 是否有这样的事情: 或者,唯一的选择是使用从? 问题答案: 在MySQL中 以秒 为单位获取Unix时间戳: 详细信息:http : //dev.mysql.com/doc/refman/5.5/en/date-and-time-functions.html#function_unix- timestamp 未经测试的

  • 这个问题我已经研究了一段时间,但我只能得到秒数,下面是给我的说明:编写一个程序,从代表纳秒数的标准输入中读取一个非负整数。然后,程序编写一行输出,给出等效的天、小时、分钟、秒、毫秒、微秒和纳秒的数量。例如,输入为123456789123456789。则输出为:123456789123456789纳秒等于1428天、21小时、33分钟、9秒、123毫秒、456微秒和789纳秒。这是我写的: }

  • 问题内容: 我通过传递ipAddress来对方法进行调用,它会返回ipAddress的位置,例如国家/地区,城市等。因此,我试图查看每个调用花费的时间。因此,我在调用方法之前设置了start_time,在调用之后设置了end_time。 所以有时候我得到的差为0 。并且resp包含有效的响应。 因此,这意味着有时需要0毫秒才能恢复响应。任何建议将不胜感激。 问题答案: 试试这个