1. 类型
clock_t: 是个long型,用来记录一段时间内的时钟计时单元数,即CPU的运行单元时间。
size_t: 标准C库中定义的,应为unsigned int,在64位系统中为long unsigned int。
time_t: 从1970年1月1日0时0分0秒到该时间点所经过的秒数。
struct tm {
  int tm_sec;       /* 秒 – 取值区间为[0,59] */
  int tm_min;       /* 分 - 取值区间为[0,59] */
  int tm_hour;      /* 时 - 取值区间为[0,23] */
  int tm_mday;      /* 一个月中的日期 - 取值区间为[1,31] */
  int tm_mon;       /* 月份(从一月开始,0代表一月) - 取值区间为[0,11] */
  int tm_year;      /* 年份,其值等于实际年份减去1900 */
  int tm_wday;      /* 星期 – 取值区间为[0,6],其中0代表星期天,1代表星期一,以此类推 */
  int tm_yday;      /* 从每年的1月1日开始的天数 – 取值区间为[0,365],其中0代表1月1日,1代表1月2日,以此类推 */
  int tm_isdst;     /* 夏令时标识符,实行夏令时的时候,tm_isdst为正。不实行夏令时的进候,tm_isdst为0;不了解情况时,tm_isdst()为负。*/
};
2. 时间的操作
clock: 返回时钟计时单元数,自从这个程序开始运行。
time: 返回当前的time_t。
difftime: 计算time_t两个之间的时间差。
3. 转换
mktime: 转换tm structure成time_t
asctime: 转换tm structure成字符串
ctime: 转换time_t成字符串
gmtime: 转换time_t成tm as UTC time
localtime: 转换time_t成tm as local time
strftime: 格式时间成字符串
转换成字符串的几个函数:asctime, ctime, strftime
4. 宏
CLOCKS_PER_SEC: 它用来表示一秒钟会有多少个时钟计时单元。

// 测量事件的持续时间  
void test_clock_t()  
{  
    long i = 100000000L;  
    clock_t start, finish;  
    double duration;  
    start = clock();  
  
    /* 测量一个事件持续的时间 */  
    while(i--) {};  
  
    finish = clock();  
    duration = (double)(finish - start) / CLOCKS_PER_SEC;  
    printf("Time to do 100000000 empty loops is %f seconds\n", duration);  
}  
  
void test_time_t()  
{  
    time_t t = time(NULL);  
    printf("The Calendar Time now is %d\n", t);  
}  
  
void test_difftime()  
{  
    time_t start,end;  
    start = time(NULL);  
    system("pause");  
    end = time(NULL);  
    printf("The pause used %5.4f seconds.\n", difftime(end, start));  
}  
  
// 下面都是一些转换函数的应用  
// mktime: tm --> time_c  
void test_mktime()  
{  
    struct tm t;  
    time_t t_of_day;  
    t.tm_year = 1997 - 1900;  
    t.tm_mon = 6;  
    t.tm_mday = 1;  
    t.tm_hour = 0;  
    t.tm_min = 0;  
    t.tm_sec = 1;  
    t.tm_wday = 4; /* Day of the week */  
    t.tm_yday = 0; /* Does not show in asctime */  
    t.tm_isdst = 0;  
  
    t_of_day = mktime(&t);  
    printf(ctime(&t_of_day));  
}  
  
// localtime: time_c --> tm  
void test_localtime()  
{  
    time_t rawtime;  
    struct tm* timeinfo;  
  
    time(&rawtime);  
    timeinfo = localtime(&rawtime);  
    printf("Current local time and date: %s", asctime(timeinfo));  
}  
  
// gmtime: time_c --> tm  
void test_gmtime()  
{  
    time_t rawtime;  
    struct tm* timeinfo;  
  
    time(&rawtime);  
    timeinfo = gmtime(&rawtime);  
    printf("UTC time and date: %s", asctime(timeinfo));  
}  
  
// ctime: time_t --> string  
void test_ctime()  
{  
    time_t t = time(NULL);  
    std::string str = ctime(&t);  
    std::cout << str << std::endl;  
}

ctime 时间的更多相关文章

  1. C语言获取时间

    转载:http://www.cnblogs.com/fzhe/archive/2012/11/06/2757858.html C语言获取系统时间的几种方式   C语言中如何获取时间?精度如何? 1 使 ...

  2. C语言获取系统时间的几种方式[转]

    C语言获取系统时间的几种方式 C语言中如何获取时间?精度如何? 1 使用time_t time( time_t * timer ) 精确到秒 2 使用clock_t clock() 得到的是CPU时间 ...

  3. linux atime ctime mtime

    touch testtime 1. stat testtime[为文件名] 可以查看这个文件名的三者状态 2.ll testtime;ll --time=atime testtime ;ll --ti ...

  4. 在CTime类中重载&lt;&lt;和&gt;&gt;

    程序代码: #include <iostream> using namespace std; class CTime//时间类 { private: unsigned short int ...

  5. 关于Ctime库

    --------------------- 本文来自 Fuko_Ibuki 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/qq_31908675/article/de ...

  6. C语言获取系统时间的几种方式

    C语言获取系统时间的几种方式 2009-07-22 11:18:50|  分类: 编程学习 |字号 订阅     C语言中如何获取时间?精度如何? 1 使用time_t time( time_t * ...

  7. Linux 下的三种时间介绍

    Linux 下的三种时间介绍: Access Time:简写为atime,表示文件访问的时间,当文件内容被访问时,更新atime时间 Modify Time:简写为mtime,表示文件内容修改的时间, ...

  8. VS2010/MFC编程入门之四十三(MFC常用类:CTime类和CTimeSpan类)

    上一节中鸡啄米讲了MFC常用类CString类的用法,本节继续讲另外两个MFC常用类-日期和时间类CTime类和CTimeSpan类. 日期和时间类简介 CTime类的对象表示的时间是基于格林威治标准 ...

  9. MFC:CTime类和CTimeSpan类

    CTime类 CTime类表示日期和时间,上限是3000年12月31日,下限是1970年1月1日 12:00:00 AM GMT. CTime(); 构造一个未经初始化的CTime对象.此状态的CTi ...

随机推荐

  1. 高性能页面加载技术--BigPipe设计原理及Java简单实现

    1.技术背景 动态web网站的历史可以追溯到万维网初期,相比于静态网站,动态网站提供了强大的可交互功能.经过几十年的发展,动态网站在互动性和页面显示效果上有了很大的提升,但是对于网站动态网站的整体页面 ...

  2. ACdream1092

    题意是给出某个地鼠的出现位置以及出现时间,人有一个移动速度,求此人最多可以打多少个地鼠? 我们根据时间把所有的地鼠排序,如果两个地鼠之间的距离不超过时间只差与速度的乘积,那说明打完上一只地鼠还可以打到 ...

  3. NOIP2011

    DAY1 铺地毯 (carpet.cpp/c/pas) 模拟 倒序离线处理 program carpet; var l,w:..,..] of longint; n,i,a,b,g,k,x,y:lon ...

  4. 【刷题】BZOJ 1537 [POI2005]Aut- The Bus

    Description Byte City 的街道形成了一个标准的棋盘网络 – 他们要么是北南走向要么就是西东走向. 北南走向的路口从 1 到 n编号, 西东走向的路从1 到 m编号. 每个路口用两个 ...

  5. 【BZOJ4036】按位或(Min-Max容斥,FWT)

    [BZOJ4036]按位或(Min-Max容斥,FWT) 题面 BZOJ 洛谷 题解 很明显直接套用\(min-max\)容斥. 设\(E(max\{S\})\)表示\(S\)中最晚出现元素出现时间的 ...

  6. BZOJ 1013 | 一份写了一堆注释的高斯消元题解

    题意 给出\(n\)维直角坐标系中\(n + 1\)个点的坐标,它们都在一个\(n\)维球面上,求球心坐标. 题解 设球面上某两个点坐标为\((a_1, a_2, ... a_n)\)和\((b_1, ...

  7. 【bzoj2002】 Hnoi2010—Bounce 弹飞绵羊

    http://www.lydsy.com/JudgeOnline/problem.php?id=2002 (题目链接) 题意 数轴上${n}$个点,每个点有一个权值${a_i}$,如果到达这个点,接下 ...

  8. 如何让自己的广播只让指定的 app 接收?

    1.自己的应用(假设名称为应用 A)在发送广播的时候给自己发送的广播添加自定义权限,假设权限名为:com.itheima.android.permission , 然后需要在应用 A 的 Androi ...

  9. 2018.9.22 Bubble Cup 11-Finals(Online Mirror,Div.2)

    感受了一下ACM的感觉,然后被神题和神犇们暴踩了 夭寿啦,机房大佬非法组队啊 比赛前i207M插的“怕不是不到九点就要弃疗”的flag成功生效 一开始先扫了一遍题,我一开始以为A题是个扫一遍的题,然后 ...

  10. bzoj 4519: [Cqoi2016]不同的最小割 最小割树

    怎么求一张无向图中任意两点之间的最小割? http://fanhq666.blog.163.com/blog/static/8194342620113495335724/ 一张无向图不同的最小割最多有 ...