Linux下Ping -T 返回的时间戳怎么看

Linux下Ping -T 返回的时间戳怎么看,第1张

首先不同系统的ping给出的跳数是不一样的,比如你这里TS:下面给出了4跳,而我在我的linux上给出了9跳:

$ ping -T tsonly 10249641

PING 10249641 (10216411) 56(124) bytes of data

64 bytes from 10216411: icmp_req=1 ttl=248 time=231 ms

TS:  29437933 absolute

-15

18

-2

9

-7

74

9

64

Unrecorded hops: 10

再来看看第一个值29437933 ,这其实是你GMT,就是你运行ping里的格林尼治时间,我们来换算一下:

>>> 29437933/3600000

8

>>> 29437933/3600000

817720361111111

>>> (29437933-83600000)/60000

10632216666666666

>>> (29437933-83600000)

637933

>>> 637933-1060000

37933

>>> 37933/1000

37

所以就是GMT:8:10:37:933,希望能帮到你

1) 计时,也就是获取当前的时间,使用 gettimeofday(),精度 1 毫秒。x86_64 下是用户态实现,无上下文切换且不陷入内核,效率非常高。

clock_gettime() 精度可到纳秒,但需要陷入内核,效率较低。

2) 定时,使用 timerfd_create() / timerfd_gettime() / timerfd_settime()。实现确保不使用 SIGALRM 信号,避免冲突和多线程问题。精度可到纳秒。

linuxsleep函数不准解决办法如下:

如下面的一段程序:

应用程序:

#include <syswaith>

usleep(n) //n微秒

Sleep(n)//n毫秒

sleep(n)//n秒

驱动程序:

#include <linux/delayh>

mdelay(n) //milliseconds 其实现

#ifdef notdef

#define mdelay(n) (\

{unsigned long msec=(n); while (msec--) udelay(1000);})

#else,linuxsleep函数不准就可以调整为正确的了。

楼上的想让你的程序变成悲剧linux下sleep函数的参数是秒为单位的休眠200秒

睡眠小于1秒用usleep,单位是毫秒

所以,楼上的程序把sleep改成usleep就可以 了

while(1)

{

/ any thing you want to do/

usleep(200);

}

另外我觉得你要说的好像是:希望while循环执行某些 *** 作,执行时间到200毫秒之后退出while循环?

最简单是用间隔定时器

你查下这几个函数:timer_create,timer_settime等。

时间设置比较精确,可以设置一段时间间隔,过了指定的时间之后,会给当前进程发送一个SIGALRM信号,你while循环的条件,可以在SIGALRM的信号处理函数里面修改,这样,到时间之后while就可以退出了

这样写:

//

static char flag=1

int main(void)

{

signal(SIGALRM, timer_handler);

/

申请并且设置间隔定时器的间隔

/

while(flag)

{

/循环内的 *** 作/

}

return 0;

}

void timer_handler(unsigned int signal)

{

flag=0;

}

//方案— 优点:仅使用C标准库;缺点:只能精确到秒级

#include <timeh>

#include <stdioh>

int main( void )

{

time_t t = time(0);

char tmp[64];

strftime( tmp, sizeof(tmp), "%Y/%m/%d %X %A 本年第%j天 %z",localtime(&t) );

puts( tmp );

return 0;

}

size_t strftime(char strDest, size_t maxsize, const char format, const struct tm timeptr);

根据格式字符串生成字符串。

struct tm localtime(const time_t timer);

取得当地时间,localtime获取的结果由结构tm返回

返回的字符串可以依下列的格式而定:

%a 星期几的缩写。Eg:Tue

%A 星期几的全名。 Eg: Tuesday

%b 月份名称的缩写。

%B 月份名称的全名。

%c 本地端日期时间较佳表示字符串。

%d 用数字表示本月的第几天 (范围为 00 至 31)。日期

%H 用 24 小时制数字表示小时数 (范围为 00 至 23)。

%I 用 12 小时制数字表示小时数 (范围为 01 至 12)。

%j 以数字表示当年度的第几天 (范围为 001 至 366)。

%m 月份的数字 (范围由 1 至 12)。

%M 分钟。

%p 以 ''AM'' 或 ''PM'' 表示本地端时间。

%S 秒数。

%U 数字表示为本年度的第几周,第一个星期由第一个周日开始。

%W 数字表示为本年度的第几周,第一个星期由第一个周一开始。

%w 用数字表示本周的第几天 ( 0 为周日)。

%x 不含时间的日期表示法。

%X 不含日期的时间表示法。 Eg: 15:26:30

%y 二位数字表示年份 (范围由 00 至 99)。

%Y 完整的年份数字表示,即四位数。 Eg:2008

%Z(%z) 时区或名称缩写。Eg:中国标准时间

%% % 字符。

//方案二 优点:能精确到毫秒级;缺点:使用了windows API

#include <windowsh>

#include <stdioh>

int main( void )

{

SYSTEMTIME sys;

GetLocalTime( &sys );

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

return 0;

}

//方案三,优点:利用系统函数,还能修改系统时间

//此文件必须是c++文件

#include<stdlibh>

#include<iostream>

using namespace std;

void main()

{

system("time");

}

//方案四,将当前时间折算为秒级,再通过相应的时间换算即可

//此文件必须是c++文件

#include<iostream>

#include<ctime>

using namespace std;

int main()

{

time_t now_time;

now_time = time(NULL);

cout<<now_time;

return 0;

}

以上就是关于Linux下Ping -T 返回的时间戳怎么看全部的内容,包括:Linux下Ping -T 返回的时间戳怎么看、linux下c++的clock统计时间怎么不准、linuxsleep函数不准等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址:https://54852.com/web/9353843.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存