Linux不同时钟的区别
今天发现项目中调用 clock_gettime 函数传入时钟类型参数时有 CLOCK_MONOTONIC、CLOCK_MONOTONIC_RAW、CLOCK_BOOTTIME、CLOCK_REALTIME 几种,对这几种时钟类型的区别有些疑惑,于是查阅了函数的说明文档,编写代码测试,以加深对clock_gettime 函数的理解
测试代码
#include <time.h>
#include<iostream>
using namespace std;
void mono_time_test()
{
struct timespec sp;
clock_gettime(CLOCK_MONOTONIC, &sp);
std::cout << "mono_time...sec:" << sp.tv_sec << std::endl;
}
void real_time_test()
{
struct timespec sp;
clock_gettime(CLOCK_REALTIME, &sp);
std::cout << "real_time...sec:" << sp.tv_sec << std::endl;
}
void boot_time_test()
{
struct timespec sp;
clock_gettime(CLOCK_BOOTTIME, &sp);
std::cout <<"boot_time..sec:" << sp.tv_sec << std::endl;
}
void mono_raw_time_test()
{
struct timespec sp;
clock_gettime(CLOCK_MONOTONIC_RAW, &sp);
std::cout << "mono_raw_time...sec:" << sp.tv_sec << std::endl;
}
int main(int argc, char* argv[])
{
mono_time_test();
mono_raw_time_test();
boot_time_test();
real_time_test();
return 1;
}
- 使用以下命令编译代码,生成测试程序
[wl@ecs-centos-7 my]$ g++ -o main main.cpp
[wl@ecs-centos-7 my]$ ll
total 16
-rwxrwxr-x 1 wl wl 9264 Apr 10 23:30 main
-rw-rw-r-- 1 wl wl 848 Apr 10 23:23 main.cpp
机器时间测试
- 修改机器时间前,执行测试程序,输出如下结果
[wl@ecs-centos-7 my]$ ./main
mono_time...sec:71
mono_raw_time...sec:71
boot_time..sec:71
real_time...sec:1586532575
[wl@ecs-centos-7 my]$ date -d "1970-01-01 UTC 1586532575 seconds" "+%F %T"
2020-04-10 23:29:35
- 执行以下命令,修改机器时间
[root@ecs-centos-7 my]$ date -s "2020-04-11 23:30:08"
- 机器时间修改完成,执行测试程序,输出如下结果
[root@ecs-centos-7 my]# date
Sat Apr 11 23:30:01 CST 2020
[wl@ecs-centos-7 my]$ ./main
mono_time...sec:178
mono_raw_time...sec:178
boot_time..sec:178
real_time...sec:1586619008
[wl@ecs-centos-7 ~]$ date -d "1970-01-01 UTC 1586619008 seconds" "+%F %T"
2020-04-11 23:30:08
测试结果
CLOCK_MONOTONIC、CLOCK_MONOTONIC_RAW、CLOCK_BOOTTIME 都不随物理机器时间改变而改变
CLOCK_REALTIME 是随物理机器时间改变而改变的
系统休眠测试
下面测试系统休眠对几种时钟的影响,为了对比休眠测试的结果,休眠前后都需要执行一次测试程序
- 休眠前,执行测试程序,下面是输出结果
[wl@ecs-centos-7 my]$ ./main
mono_time...sec:45
mono_raw_time...sec:45
boot_time..sec:45
real_time...sec:1586535342
- 执行以下命令,使系统进入休眠
注意:systemctl suspend 命令需要慎重,为避免执行后无法唤醒系统,建议先确保机器可以唤醒休眠。我是通过云服管理后台唤醒系统的
[wl@ecs-centos-7 my]$ systemctl suspend
==== AUTHENTICATING FOR org.freedesktop.login1.suspend ===
Authentication is required for suspending the system.
Authenticating as: root
Password:
==== AUTHENTICATION COMPLETE ===
- 唤醒系统,执行测试程序,下面是输出结果
[wl@ecs-centos-7 my]$ ./main
mono_time...sec:237
mono_raw_time...sec:237
boot_time..sec:367
real_time...sec:1586535664
测试结果
CLOCK_MONOTONIC、CLOCK_MONOTONIC_RAW 不包含系统休眠期间的时间
CLOCK_BOOTTIME、CLOCK_REALTIME 包含系统休眠期间的时间
物理机器重启测试
- 重启机器之前,执行测试程序,下面是输出结果
[wl@ecs-centos-7 my]$ ./main
mono_time...sec:2510
mono_raw_time...sec:2510
boot_time..sec:2640
real_time...sec:1586537938
- 执行以下命令重启机器
[wl@ecs-centos-7 my]$ reboot
==== AUTHENTICATING FOR org.freedesktop.login1.reboot ===
Authentication is required for rebooting the system.
Authenticating as: root
Password:
==== AUTHENTICATION COMPLETE ===
- 重启完成,执行测试程序,下面是输出结果
[wl@ecs-centos-7 my]$ ./main
mono_time...sec:41
mono_raw_time...sec:41
boot_time..sec:41
real_time...sec:1586537997
测试结果
- 重启物理机器对 CLOCK_REALTIME 没有任何影响
- 重启物理机器后, CLOCK_MONOTONIC、CLOCK_MONOTONIC_RAW、CLOCK_BOOTTIME 时间全部重新计数
参考
https://linux.die.net/man/2/clock_gettime
Linux不同时钟的区别的更多相关文章
- linux系统时钟和硬件时钟不一致
在做DB2 集群复制的时候要求两台主机时间相互一致. 但是在一台主机上系统时间和硬件时间相差12个小时左右:手动同步后,重启后又相差12个小时左右. 为什么会是这样的,先介绍下系统时钟和硬件时钟的区别 ...
- linux 实时时钟(RTC)驱动【转】
转自:http://blog.csdn.net/yaozhenguo2006/article/details/6820218 这个是linux内核文档关于rtc实时时钟部分的说明,此文档主要描述了rt ...
- Linux 系统时钟(date) 硬件时钟(hwclock)
/********************************************************************* * Linux 系统时钟(date) 硬件时钟(hwclo ...
- linux 通用时钟框架CCF
linux CCF 时钟框架 简单介绍 这里讲的时钟是给soc各组件提供时钟的树状框架,并非内核使用的时间,和其它模块一样,clk也有框架,用以适配不同的平台.适配层之上是客户代码和接口,也就是各模块 ...
- linux 和unix 的区别
Linux与Unix的区别 某些PC机的Unix和Linux在实现方面相类似.几乎所有的商业Unix版本都基本支持同样的软件.程序设计环境和网络特性.然而,Linux和Unix的商业版本依然存在许多 ...
- Linux系统时钟的更改
linux系统时钟有两个,一个是硬件时钟,即BIOS时间,就是我们进行CMOS设置时看到的时间,另一个是系统时钟,是linux系统Kernel时间. 查看.设置硬件时间: 查看系统硬件时钟 hwclo ...
- Linux的优缺点,Linux与windows的区别
Linux 一. 什么是linux? Linux是一套免费使用和自由传播的类Unix操作系统,是一个多用户.多任务.支持多线程和多CPU的操作系统.它能运行主要的UNIX工具软件.应用程序和网络协议. ...
- php windows与linux下的路径区别
php windows与linux下的路径区别windows用的是"\",linux用的是"/"这一点要特别清楚,, ps:在PHP windows也可以用/表 ...
- Linux系统 关机/重启/用户切换/注销,用户管理(用户创建/修改,用户组增加/删除),Linux中 / 和 ~ 的区别
1.关机/重启命令 shutdown命令 shutdown -h now :立即关机 shutdown -h 1 :1分钟后关机 shutdown -r now :立即重启 shutdown -r 1 ...
随机推荐
- Java多线程并发04——合理使用线程池
在此之前,我们已经了解了关于线程的基本知识,今天将为各位带来,线程池这一技术.关注我的公众号「Java面典」了解更多 Java 相关知识点. 为什么使用线程池?线程池做的工作主要是控制运行的线程的数量 ...
- JDBC工具类实现登陆验证-Java(新手)
JDBC工具类: package cn.chuang.JdbcDome; import java.sql.*; public class JdbcUtilss { private static fin ...
- hdu1035 机器人走格子,格子指明方向,问几步走出格子或者是否有形成圈
只要根据格子的方向选择下一步搜索的方向即可,退出条件是出界或者进入环中,进入环中的条件也很好确定,就是一个点走了两次,由于路径是固定的,这就会陷入无限循环. #include<iostream& ...
- 【前端词典】这些功能其实不需要 JS,CSS 就能搞定
前言 今天我们大家介绍一些你可能乍一眼以为一定需要 JavaScript 才能完成的功能,其实 CSS 就能完成,甚至更加简单. 内容已经发布在 gitHub 了,欢迎围观 Star,更多文章都在 g ...
- c#委托、泛型委托和匿名方法
题外话:别指望看第一遍书就能记住和掌握什么——请看第二遍.第三遍. 本人女猿一枚,2年工作经验,喜欢钻研,喜欢创新,闲暇之余喜欢写写博客,深知自身能力薄弱,如表达错误.不当之处请园友们多多指出,互相交 ...
- OpenCV -Python 性能衡量和提升技术 | 十二
目标 在图像处理中,由于每秒要处理大量操作,因此必须使代码不仅提供正确的解决方案,而且还必须以最快的方式提供.因此,在本章中,你将学习 衡量代码的性能. 一些提高代码性能的技巧. 你将看到以下功能:c ...
- iOS 状态栏显示/隐藏
iOS 10为止,将在plist文件中将 View controller-based status bar appearance 设置为NO,就可以用UIApplication设置状态栏. 注意,要在 ...
- [Asp.Net Core] 关于 Blazor Server Side 的一些杂项, 感想
在2016年, 本人就开始了一个内部项目, 其特点就是用C#构建DOM树, 然后把DOM同步到浏览器中显示. 并且在一些小工程中使用. 3年下来, 效果很不错, 但因为是使用C#来构建控件树, 在没有 ...
- Python math库和random库
1.math库 >>> from math import * >>> 2*pi 6.283185307179586 >>> e 2.7182818 ...
- Java 类加载器解析及常见类加载问题
Java 类加载器解析及常见类加载问题 java.lang.ClassLoader 每个类加载器本身也是个对象--一个继承 java.lang.ClassLoader 的实例.每个类被其中一个实例加载 ...