C++14系列(2):C/C++的时间函数
C++笔记開始
为了好好研究下C++14。顺便复习下曾经的C++知识。搞了个git(不断完好中):
https://github.com/rododo/cpp14examples.git
里面会慢慢封装一些经常使用的函数。并做一些測试验证。project是建立在Ubuntu的Eclipse之上,见系列(1)环境搭建。
经常使用的时间函数
參考:
http://blog.chinaunix.net/uid-24517893-id-363870.html
时间函数经常使用到的几个概念:Calendar Time(日历时间)。epoch(时间点),clock tick(时钟计时单元)Coordinated Universal Time(UTC):世界标准时间,即格林威治标准时间(Greenwich Mean Time,GMT)。
epoch:时间点。
在标准C/C++中是一个整数,它用当前的时间和标准时间点的相差秒数来表示。它能够理解成日历时间,由于它已经是一个差值了。
日历时间(Calendar Time),是用“从一个标准时间点到此时的时间经过的秒数”来表示的时间。
clock tick:时钟计时单元。一个时钟计时单元的时间长短是由CPU控制的。一个clock tick不是CPU的一个时钟周期。而是C/C++的一个基本计时单位。
进程的CPU使用时间计时
C/C++中的cpu使用计时函数是clock(),而与其相关的数据类型是clock_t。这个函数返回从“开启这个程序进程”到“程序中调用clock()函数”时之间的CPU时钟计时单元(clock tick)数。当中clock_t是用来保存时间的数据类型。
clock_t是一个长整形数。在time.h文件里,还定义了一个常量CLOCKS_PER_SEC,它用来表示一秒钟会有多少个时钟计时单元,例如以下打印的是进程执行至今占用的cpu时间秒数。而且它是算单核的秒数,假设这个程序是多线程的。core1和core2同一时候被某程序的两个线程使用了5s的cpu执行时间片。那么此时打印的应该是10s(已经验证)。
printf("Elapsed time:%u secs.\n",clock()/CLOCKS_PER_SEC);
日历时间
在C/C++中通过 < time.h > 里的time函数获得日历时间。日历时间(Calendar Time)是通过time_t数据类型来表示的。用time_t表示的时间(日历时间)是从一个时间点(比如:1970年1月1日0时0分0秒)到此时的秒数。time_t实际上是长整型。
用time()函数结合其它函数(如:localtime、gmtime、asctime、ctime)能够获得当前系统时间或是标准时间。
time_t time(time_t * timer);
日历时间(秒)与日期(年月日)关系
在标准C/C++中。我们可通过tm结构来获得日期。tm结构在time.h中有定义,相当于一个包括了年月日小时分钟等的结构体。
ANSI C标准称使用tm结构的这样的时间表示为分解时间(broken-down time)。
而日历时间(Calendar Time)是从一个时间点到此时的秒数,类型比較简单。
在time.h头文件里,我们还能够看到一些函数,它们都是以time_t为參数类型或返回值类型的函数:
double difftime(time_t time1, time_t time0);
time_t mktime(struct tm * timeptr);
time_t time(time_t * timer);
char * asctime(const struct tm * timeptr);
char * ctime(const time_t *timer);
此外。time.h还提供了两种不同的函数将日历时间(一个用time_t表示的整数)转换为我们平时看到的把年月日时分秒分开显示的时间格式tm:
struct tm * gmtime(const time_t *timer);
struct tm * localtime(const time_t * timer);
固定的日期格式打印
使用函数:
char * asctime(const struct tm * timeptr);
char * ctime(const time_t *timer);
打印结果:
比如 Wed Jan 02 02:03:55 1980\n\0
当中asctime()函数是通过tm结构来生成字符串。所以能够传给世界时间或者本地时间,而ctime()是通过日历时间来生成字符串。ctime()函数须要先參照本地的时间设置,把日历时间转化为本地时间,然后再生成格式化后的字符串。所以一般其打印的是本地时间字符串。
自己定义的日期格式打印
使用strftime()函数将时间格式化为想要的格式。它的原型例如以下:
size_t strftime(
char *strDest,
size_t maxsize,
const char *format,
const struct tm *timeptr
);
样例:
strftime(str,100,"It is now %I %p",ptr);
printf(str);
其执行结果为:
It is now 4PM
样例:
strftime( tmpbuf, 128, "Today is %A, day %d of %B in the year %Y.\n", newtime);
printf(tmpbuf);
执行结果:
Today is Saturday, day 30 of July in the year 2005.
分解时间转化为日历时间
分解时间,在C/C++中指tm结构。我们能够使用mktime()函数将tm结构转化为日历时间。其函数原型例如以下:
time_t mktime(struct tm * timeptr);
< sys/time.h >的计时函数
除了上述的标准C/C++用到的时间函数外,Linux系统也提供了一个函数。能够精确到微秒。
这就是gettimeofday函数,它获得的时间精确到微秒(1e-6 s)量级。
在一段代码前后分别使用例如以下:
struct timeval tv_begin, tv_end;
gettimeofday(&tv_begin, NULL);
foo();
gettimeofday(&tv_end, NULL);
结构体timeval的定义为:
struct timeval{
long int tv_sec; // 秒数
long int tv_usec; // 微秒数
}
time仅仅能返回秒级的返回值。而该结构体能精确到微秒级。
该函数和time函数一样都是按真实世界的时间来计算的。
总结
本文介绍了C/C++中的有关日期和时间的概念,并通过各种实例讲述了这些函数和数据结构的用法。
假设要測试优化的程序的执行效率,一般測量进程在cpu上使用的时间片之和,能够用clock函数,clock函数并不代表真实世界的时间。
真实世界的时间则是time或者gettimeofday函数得到的。它们也能够用于日期的显示。
C++14系列(2):C/C++的时间函数的更多相关文章
- MySQL 笔记 —— 日期和时间函数
[TOC] 获取当前日期的函数和获取当前时间的函数 CURDATE()和CURRENT_DATE()函数获取当前日期:CURTIME()和CURRENT_TIME()函数获取当前时间. mysql&g ...
- DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate TIME Dimension)
DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate TIME Dimension) 难度: ★☆☆☆☆(1星) 适用范围: ★★★★★(5星) 这个时间系列想 ...
- 玩转Windows服务系列——Windows服务启动超时时间
最近有客户反映,机房出现断电情况,服务器的系统重新启动后,数据库服务自启动失败.第一次遇到这种情况,为了查看是不是断电情况导致数据库文件损坏,从客户的服务器拿到数据库的日志,进行分析. 数据库工作机制 ...
- DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate Date Dimension)
跟大家的交流是我的动力. :) DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate Date Dimension) 难度: ★☆☆☆☆(1星) 适用范围: ★ ...
- impala系列: 时间函数
--=======================时间函数--======================= --当前时间戳now()current_timestamp() --当前时间戳相对于 li ...
- web报表工具FineReport常用函数的用法总结(日期和时间函数)
web报表工具FineReport常用函数的用法总结(日期和时间函数) 说明:凡函数中以日期作为参数因子的,其中日期的形式都必须是yy/mm/dd.而且必须用英文环境下双引号(" " ...
- web报表工具FineReport经常使用函数的使用方法总结(日期和时间函数)
web报表工具FineReport经常使用函数的使用方法总结(日期和时间函数) 说明:凡函数中以日期作为參数因子的,当中日期的形式都必须是yy/mm/dd.并且必须用英文环境下双引號(" & ...
- Loadrunner时间函数、用时间生成订单编号例子
Loadrunner中取时间函数.用时间函数生成订单编号例子: <如要转载,请注明网络来源及作者:Cheers_Lee> 问题的提出: (1)有时候在Loadrunner中用C语言设计脚本 ...
- MySQL数据库9 - 日期与时间函数
一 日期和时间函数 函数的概念:按指定格式输入参数,返回正确结果的运算单元 1. 返回当前日期:curdate() current_date() current_date()+0可以将当前日期转换为数 ...
随机推荐
- Xcode 安装插件管理器
https://github.com/alcatraz/Alcatraz运行之后, load bundle, 然后window就有pakagegemanage. 下载如下插件: 自动导入插件
- Static Nested Class 和 Inner Class的不同?
Nested Class (一般是C++的说法),Inner Class (一般是JAVA的说法).Java内部类与C++嵌套类最大的不同就在于是否有指向外部的引用上. 注: 静态内部类(Inner ...
- 第十四章 openwrt 安装 python
需要安装libffi,python-mini,python.libffi以及python-mini需要安装在python之前 如果部分软件包不一样可以在下面的web后台搜索,搜索前先opkg ...
- HSSFWorkbook 创建Excel文件
1.项目代码实例 @Override public OutputStream exportAucLotData(String id, String password, OutputStream out ...
- JAVA泛型通配符T,E,K,V区别,T以及Class<T>,Class<?>的区别以及接口里default方法
使用大写字母A,B,C,D......X,Y,Z定义的,就都是泛型,把T换成A也一样,这里T只是名字上的意义而已 ? 表示不确定的java类型 T (type) 表示具体的一个java类型 K V ( ...
- 3D 坐标变换 公式 推导
[ 更新 ]更好的方法见[用抽象代数讨论仿射变换和仿射空间中的坐标变换] ,以下是之前的内容. 以下的推导 结论是正确的,可是过程有点懵. 以下使用行向量: e1=(1,0,0) e2=(0,1,0) ...
- [Todo] Redis相关学习
Redis与新浪 http://www.cnblogs.com/me115/p/3482783.html Redis对于多个CPU的机器,可以启动多实例. 可以看看这个(写的简单了) http://w ...
- django from组件 实现增加 删除 编辑(推荐用法)
实现效果: 代码示例: 代码: models.py from django.db import models class UserInfo(models.Model): username = mode ...
- 详解vue父组件传递props异步数据到子组件的问题
案例一 父组件parent.vue // asyncData为异步获取的数据,想传递给子组件使用 <template> <div> 父组件 <child :child-d ...
- 小课堂week17 编程范式巡礼第二季 并发那些事
编程范式巡礼第二季 并发那些事 继续上周的编程范式话题,今天想聊一下并发范式. 并发也算一种范式? 真正的并发式编程,绝不只是调用线程API或使用synchronized.lock之类的关键字那么简单 ...