使用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下,如何获得微秒级时间、一道面试题:如何确定两台电脑的时钟是否同步等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)