c语言里面gettime函数如何调用

c语言里面gettime函数如何调用,第1张

使用C语言编写程序需要获得当前精确时间(1970年1月1日到现在的时间),或者为执行计时,可以使用gettimeofday()函数

用 法: void gettime(struct time timep);

C语言函数

#include <sys/timeh>

int gettimeofday(struct timevaltv, struct timezone tz);

其参数tv是保存获取时间结果的结构体,参数tz用于保存时区结果:

struct timezone{

int tz_minuteswest;/格林威治时间往西方的时差/

int tz_dsttime;/DST 时间的修正方式/

}

timezone 参数若不使用则传入NULL即可。

而结构体timeval的定义为:

struct timeval{

long int tv_sec; // 秒数

long int tv_usec; // 微秒数

}

它获得的时间精确到微秒(1e-6 s)量级。在一段代码前后分别使用gettimeofday可以计算代码执行时间:

struct timeval tv_begin, tv_end;

gettimeofday(&tv_begin, NULL);

foo();

gettimeofday(&tv_end, NULL);

#ifdef _WIN32#include <windowsh>#else#include <timeh>#endif // _WIND32// 定义64位整形#if defined(_WIN32) && !defined(CYGWIN)typedef __int64 int64_t;#elsetypedef long long int64t;#endif // _WIN32// 获取系统的当前时间,单位微秒(us)int64_t GetSysTimeMicros(){#ifdef _WIN32// 从1601年1月1日0:0:0:000到1970年1月1日0:0:0:000的时间(单位100ns)#define EPOCHFILETIME (116444736000000000UL) FILETIME ft; LARGE_INTEGER li; int64_t tt = 0; GetSystemTimeAsFileTime(&ft); liLowPart = ftdwLowDateTime; liHighPart = ftdwHighDateTime; // 从1970年1月1日0:0:0:000到现在的微秒数(UTC时间) tt = (liQuadPart - EPOCHFILETIME) /10; return tt;#else timeval tv; gettimeofday(&tv, 0); return (int64_t)tvtv_sec 1000000 + (int64_t)tvtv_usec;#endif // _WIN32 return 0;}

这道面试题是开放的。熟悉的情境,很容易给出一个回答。但随着被面试者思维方式、知识领域及深度的不同,回答可能大相径庭。

在接着往下阅读时,你可以先想想自己的答案。

没理解题目的回答:

还算正常的回答:

电子工程师的回答:

网络工程师的回答:

……

你可能有更精彩的回答……

本实验室将采用可 *** 作的、尽可能精确的实验作为回答。

题目并没有说两台电脑是和时间服务器同步的,所以目的只是测量两台电脑之间的系统时间是否一致。

用date命令(高精度选项)直接看一下两台主机的系统时间。本地的;远程的;本地的;远程的:

显然,host2的时间读数更大一些。但这究竟是host2的时钟快了,还是ssh调用所花的时间导致的呢?现在还不好说。

假设这个时间差异是T1:

T1 = Diff + RTT12

其中,Diff 是两台电脑真实的时间差异,RTT12是host1到host2数据往返所花的时间(严格来说是ssh调用所花的时间)。

反方向做同样的测试:

host1与host2的时间差异设为T2,则:

T2 = -Diff + RTT21

简单地认为两个方向的往返时间是相等的,于是有:

Diff = (T1 – T2)/2

RTT = (T1 + T2)/2

估算一下:

上面的单位都是ns 也就是说时间差异是163~171ms, ssh路途往返耗费728ms

这个结果可信吗?于是写了一段脚本,把这个测试过程自动化,观察一段时间的结果。

下图是每秒测量一次,1个小时的测量数据。为了在对数坐标下显示,时间差异用绝对值。

说明:

在没有时间同步的情况下,观察2组/3台主机:A, B, S的时间差异。

A, B, S实际上是在ESXi上的3台虚拟机。虚拟机的时钟可能和硬件实钟会有某种同步策略,所以看到的并不是单方向的变化。

在A,B,S上都开启NTP服务,时间服务器使用Debian Linux默认的NTP server (xdebianpoolntporg)。

因为幅度悬殊的原因,实际上使用中位数更有意义。可以看到A-S或B-S的时钟差异在30~50ms

在A,B,S上都开启NTP服务,其中A,B与本地的S同步,但S还是与远程NTP server同步。

可以看到A-S或B-S的时钟差异在3ms左右,一致性比远程NTP同步高了一个数量级。

在A,B,S上都开启NTP服务,其中A,B与S同步,但S直接使用本地时钟,配置为:

server 12712710 prefer

结果有点出乎意料,时间不一致接近60ms。

由于通常的 *** 作系统是非实时 *** 作系统,同样的指令占用的执行时间并不是固定的。做一个简单的实验,看看这个因素对测量会有多大影响。

下图给出了在两台机器上,读取系统时间(gettimeofday)这一调用所花的时间(各运行500000次)

可以看出9997%的执行都在1us及以下。这说明分时执行对统计结果的影响很小。

当然,整个ssh调用耗时的波动范围更大一些(RTT的统计值上可以反映出来)。

用ssh调用读取另一台机器上的系统时间,和本地时间比较,并利用双向ssh调用抵消调用所花的时间,从而可以较准确计算出两台主机上的系统时间差。

虽然在分时 *** 作系统上不能保证执行时间的固定,但通过统计可以逼近结果。由于ssh调用所花的时间在06ms以下,所以测量的精度至少是1ms级的。

另外,如果用非加密的web调用,或者自己实现远程调用,应该会有更高的效率,可能会对测量精度略有提高。

利用这一测量,可以观察NTP的同步效果。如果和远程NTP服务器同步,时钟的一致性实测在50ms以内;如果和本地NTP服务器同步,时钟的一致性在3ms左右;但如果本地NTP服务器使用本地时钟,一致性会下降很多(60ms左右)。

由于硬件/虚拟机时钟的波动、网络的波动、NTP的精度,都导致这种一致性总是处于波动之中。总体上,在局域网内,使用NTP同步,能达到毫秒级的一致性就不错了。

在 C 语言中,可以使用 clock() 函数来获取程序的运行时间。

例如:

#include <timeh>

#include <stdioh>

int main()

{

clock_t start, end;

double elapsed;

start = clock();

// 放置要测量时间的代码

end = clock();

elapsed = (double)(end - start) / CLOCKS_PER_SEC;

printf("Elapsed time: %f\n", elapsed);

return 0;

}

在这段代码中,clock() 函数返回从程序开始运行到调用该函数时所经过的时间,以单位为 clock tick 的整数。我们可以使用 CLOCKS_PER_SEC 宏来获取每秒的 clock tick 数。

需要注意的是,clock() 函数并不能精确测量程序的运行时间,因为它会受到其他进程和系统活动的影响。

如果你需要更精确的测量程序的运行时间,可以使用 *** 作系统提供的其他函数,例如 gettimeofday() 函数。

三种方法:

1 直接使用内核变量jiffies,通用jiffies的值相减可以获得内核时间,但是此分辨率一般为10ms(可参考内核宏HZ)级

因为jiffies的值

2 do_gettimeofday()函数,其用法和系统调用gettimeofday相同 他可以得到us级的时间分辨率

3 在内核状态下直接读取CPU时间戳寄存器需要了解本身CPU的细节!

各位,知道kernel里获取系统时间的函数吗?

#ifdef __KERNEL__

#define OS_GET_TIME(pTimer) { get_fast_time(pTimer); }

#else

#include <sys/timeh>

#include <WW/ISUtilsh>

#define OS_GET_TIME(pTimer) { gettimeofday(pTimer,NULL); }

#endif / KERNEL /

显示 warning: implicit declaration of function ‘get_fast_time’ [-Wimplicit-function-declaration]

在WINDOWS系统中,请使用BCB,VC等IDE

1精确到秒:

//---------------------------------------------------------------------------

#include <stdioh>

int main(void)

{

puts(__DATE__);

puts(__TIME__);

return 0;

}

//---------------------------------------------------------------------------

2精确到毫秒的程序对 *** 作系统系统有依赖性,不同的 *** 作系统中要用不同的方法

unix系统:

//---------------------------------------------------------------------------

#include <sys/timeh>

#include <stdioh>

int main(void)

{

struct timeval tms;

time_t t;

struct tm tmm;

t=time(NULL);

tmm=localtime(&t);

gettimeofday(&tms,NULL);

printf("%d:%d:%d%d\n",tmm->tm_hour,tmm->tm_min,tmm->tm_sec,tmstv_usec/1000);

return 0;

}

//---------------------------------------------------------------------------

windows系统:

//---------------------------------------------------------------------------

#include <windowsh>

#include <stdioh>

int main( void )

{

SYSTEMTIME sys;

GetLocalTime( &sys );

printf( "%4d/%02d/%02d %02d:%02d:%02d%03d \n",syswYear,syswMonth,syswDay,syswHour,syswMinute, syswSecond,syswMilliseconds);

return 0;

}

//---------------------------------------------------------------------------

以上就是关于c语言里面gettime函数如何调用全部的内容,包括:c语言里面gettime函数如何调用、Windows下,如何获得微秒级时间、一道面试题:如何确定两台电脑的时钟是否同步等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9639951.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存