linux时间函数介绍

Linux时间函数

分类: Linux应用开发 8674人阅读 评论(4) 收藏 举报
系统环境:ubuntu10.04

简介
本文旨在为了解Linux各种时间类型与时间函数提供技术文档。

1、Linux下常用时间类型
Linux下常用时间类型有四种:time_tstruct tmstruct timevalstruct timespec

1.1 time_t时间类型
time_t类型在time.h中定义:
  1. #ifndef __TIME_T
  2. #define __TIME_T
  3. typedef long time_t;
  4. #endif
#ifndef __TIME_T
#define __TIME_T
typedef  long  time_t;
#endif
可见,time_t实际是一个长整型。其值表示为从UTC(coordinated universal time)时间197011000000(也称为Linux系统的Epoch时间)到当前时刻的秒数。由于time_t类型长度的限制,它所表示的时间不能晚于2038119031407秒(UTC)。为了能够表示更久远的时间,可用64或更长的整形数来保存日历时间,这里不作详述。
使用time()函数获取当前时间的time_t值,使用ctime()函数将time_t转为当地时间字符串。

备注UTC时间有时也称为GMT时间,其实UTCGMT两者几乎是同一概念。它们都是指格林尼治标准时间,只不过UTC的称呼更为正式一点。两者区别在于前者是天文上的概念,而后者是基于一个原子钟。

1.2 struct tm时间类型
tm结构在time.h中定义:
  1. #ifndef _TM_DEFINED
  2. struct tm{
  3. int tm_sec; /*秒 - 取值区间为[0, 59]*/
  4. int tm_min; /*分 - 取值区间为[0, 59]*/
  5. int tm_hour; /*时 - 取值区间为[0, 23]*/
  6. int tm_mday; /*日 - 取值区间为[1, 31]*/
  7. int tm_mon; /*月份 - 取值区间为[0, 11]*/
  8. int tm_year; /*年份 - 其值为1900年至今年数*/
  9. int tm_wday; /*星期 - 取值区间[0, 6],0代表星期天,1代表星期1,以此类推*/
  10. int tm_yday; /*从每年的1月1日开始的天数-取值区间为[0, 365],0代表1月1日*/
  11. int tm_isdst; /*夏令时标识符,使用夏令时,tm_isdst为正,不使用夏令时,tm_isdst为0,不了解情况时,tm_isdst为负*/
  12. };
  13. #define _TM_DEFINED
  14. #endif
#ifndef _TM_DEFINED
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, 11]*/
    int tm_year; /*年份 - 其值为1900年至今年数*/
    int tm_wday; /*星期 - 取值区间[0, 6],0代表星期天,1代表星期1,以此类推*/
    int tm_yday; /*从每年的1月1日开始的天数-取值区间为[0, 365],0代表1月1日*/
    int tm_isdst; /*夏令时标识符,使用夏令时,tm_isdst为正,不使用夏令时,tm_isdst为0,不了解情况时,tm_isdst为负*/
};
#define _TM_DEFINED
#endif
ANSI C标准称使用tm结构的这种时间表示为分解时间(broken-down time)
使用gmtime( )localtime( )可将time_t时间类型转换为tm结构体;

使用mktime( )tm结构体转换为time_t时间类型;
使用asctime( )struct tm转换为字符串形式。

1.3 struct timeval时间类型
timeval结构体在time.h中定义:
  1. Struct tmieval{
  2. time_t tv_sec; /*秒s*/
  3. suseconds_t tv_usec; /*微秒us*/
  4. };
Struct tmieval{
    time_t tv_sec; /*秒s*/
    suseconds_t tv_usec; /*微秒us*/
};
设置时间函数settimeofday( )与获取时间函数gettimeofday( )均使用该事件类型作为传参。

1.4 struct timespec时间类型
timespec结构体在time.h定义:
  1. struct timespec{
  2. time_t tv_sec; /*秒s*/
  3. long tv_nsec; /*纳秒ns*/
  4. };
struct timespec{
    time_t tv_sec; /*秒s*/
    long tv_nsec; /*纳秒ns*/
};

2、Linux下常用时间函数
Linux下常用时间函数有:time( )ctime( )gmtime( )localtime( )mktime( )asctime( )difftime( )gettimeofday( )settimeofday( )

2.1 time( )函数
头文件:#include <time.h>
函数定义:time_t time(time_t *timer)
功能描述:该函数返回从197011000000秒至今所经过的秒数。如果time_t *timer非空指针,函数也会将返回值存到timer指针指向的内存。
返回值:成功则返回秒数,失败则返回((time_t)-1)值,错误原因存于errno中。
例:
  1. time_t seconds;
  2. seconds = time((time_t *)NULL);
time_t seconds;
seconds = time((time_t *)NULL);

2.2 ctime( )函数
头文件:#include <time.h>
函数定义:char *ctime(const time_t *timep);
功能描述:ctime( )将参数timep指向的time_t时间信息转换成实际所使用的时间日期表示方法,并以字符串形式返回。字符串格式为:"Wed Jun 20 21:00:00 2012\n"
例:
  1. time_t timep;
  2. tmep = time(NULL);
  3. printf("%s\n", ctime(&timep));
time_t timep;
tmep = time(NULL);
printf("%s\n", ctime(&timep));

2.3 gmtime( )函数
头文件:#include <time.h>
函数定义:struct tm *gmtime(const time_t *timep)
功能描述:gmtime( )将参数timep指向的time_t时间信息转换成以tm结构体表示的GMT时间信息,并以struct tm*指针返回。
GMTGMT是中央时区, 北京 在东8,相差8个小时,所以北京时间=GMT时间+8小时
例:
  1. int main(void)
  2. {
  3. char *wday[] = {"Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"};
  4. time_t timep;
  5. struct tm *p_tm;
  6. timep = time(NULL);
  7. p_tm = gmtime(&timep); /*获取GMT时间*/
  8. printf("%d-%d-%d ", (p_tm->tm_year+1900), (p_tm->mon+1), p_tm->tm_mday);
  9. printf("%s %d:%d:%d\n", wday[p_tm->tm_wday], p_tm->tm_hour, p_tm->tm_min, p_tm->tm_sec);
  10. }
int main(void)
{
    char *wday[] = {"Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"};
    time_t timep;
    struct tm *p_tm;
    timep = time(NULL);
    p_tm = gmtime(&timep); /*获取GMT时间*/
    printf("%d-%d-%d ", (p_tm->tm_year+1900), (p_tm->mon+1), p_tm->tm_mday);
    printf("%s %d:%d:%d\n", wday[p_tm->tm_wday], p_tm->tm_hour, p_tm->tm_min, p_tm->tm_sec);
}

2.4 localtime( )函数
头文件:#include <time.h>
函数定义:struct tm *localtime(const time_t *timep);
功能描述:localtime( )将参数timep指向的time_t时间信息转换成以tm结构体表示的本地时区时间(如北京时间= GMT+小时)
例:
  1. int main(void)
  2. {
  3. char *wday[] = {"Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"};
  4. time_t timep;
  5. struct tm *p_tm;
  6. timep = time(NULL);
  7. p_tm = localtime(&timep); /*获取本地时区时间*/
  8. printf("%d-%d-%d ", (p_tm->tm_year+1900), (p_tm->mon+1), p_tm->tm_mday);
  9. printf("%s %d:%d:%d\n", wday[p_tm->tm_wday], p_tm->tm_hour, p_tm->tm_min, p_tm->tm_sec);
  10. return 0;
  11. }
int main(void)
{
    char *wday[] = {"Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"};
    time_t timep;
    struct tm *p_tm;
    timep = time(NULL);
    p_tm = localtime(&timep); /*获取本地时区时间*/
    printf("%d-%d-%d ", (p_tm->tm_year+1900), (p_tm->mon+1), p_tm->tm_mday);
    printf("%s %d:%d:%d\n", wday[p_tm->tm_wday], p_tm->tm_hour, p_tm->tm_min, p_tm->tm_sec);
    return 0;
}

2.5 mktime( )函数
头文件:#include <time.h>
函数定义:time_t mktime(struct tm *p_tm);
功能描述:mktime( )将参数p_tm指向的tm结构体数据转换成从197011000000秒至今的GMT时间经过的秒数。
例:
  1. int main(void)
  2. {
  3. time_t timep:
  4. struct tm *p_tm;
  5. timep = time(NULL);
  6. pintf("time( ):%d\n", timep);
  7. p_tm = local(&timep);
  8. timep = mktime(p_tm);
  9. printf("time( )->localtime( )->mktime( ):%d\n", timep);
  10. return 0;
  11. }
int main(void)
{
    time_t timep:
    struct tm *p_tm;
    timep = time(NULL);
    pintf("time( ):%d\n", timep);
    p_tm = local(&timep);
    timep = mktime(p_tm);
    printf("time( )->localtime( )->mktime( ):%d\n", timep);
    return 0;
}

2.6 asctime( )函数
头文件:#include <time.h>
函数定义:char *asctime(const struct tm *p_tm);
功能描述:asctime( )将参数p_tm指向的tm结构体数据转换成实际使用的时间日期表示方法,并以字符串形式返回(ctime函数相同)。字符串格式为:"Wed Jun 20 21:00:00 2012\n"
例:
  1. int main(void)
  2. {
  3. time_t timep;
  4. timep = time(NULL);
  5. printf("%s\n", asctime(gmtime(&timep)));
  6. return 0;
  7. }
int main(void)
{
    time_t timep;
    timep = time(NULL);
    printf("%s\n", asctime(gmtime(&timep)));
    return 0;
}

2.7 difftime( )函数
头文件:#include <time.h>
函数定义:double difftime(time_t timep1, time_t timep2);
功能描述:difftime( )比较参数timep1timep2时间是否相同,并返回之间相差秒数。
例:
  1. int main(void)
  2. {
  3. time_t timep1, timep2;
  4. timep1 = time(NULL);
  5. sleep(2);
  6. timep2 = time(NULL);
  7. printf("the difference is %f seconds\n", difftime(timep1, timep2));
  8. return 0;
  9. }
int main(void)
{
    time_t timep1, timep2;
    timep1 = time(NULL);
    sleep(2);
    timep2 = time(NULL);
    printf("the difference is %f seconds\n", difftime(timep1, timep2));
    return 0;
}

2.8 gettimeofday( )函数
头文件:#include <sys/time.h>
#include <unistd.h>
函数定义:int gettimeofday(struct timeval *tv, struct timezone *tz);
功能描述:gettimeofday( )把目前的时间信息存入tv指向的结构体,当地时区信息则放到tz指向的结构体。
struct timezone原型:
  1. struct timezone{
  2. int tz_minuteswest; /*miniutes west of Greenwich*/
  3. int tz_dsttime; /*type of DST correction*/
  4. };
struct timezone{
    int tz_minuteswest; /*miniutes west of Greenwich*/
    int tz_dsttime; /*type of DST correction*/
};
例:
  1. struct timeval tv;
  2. struct timeval tz;
  3. gettimeofday(&tv, &tz);
struct timeval tv;
struct timeval tz;
gettimeofday(&tv, &tz);

附:
使用time函数族获取时间并输出指定格式字符串例子(strftime( )函数):
  1. int main(void)
  2. {
  3. char strtime[20] = {0};
  4. time_t timep;
  5. struct tm *p_tm;
  6. timep = time(NULL);
  7. p_tm = localtime(&timep);
  8. strftime(strtime, sizeof(strtime), "%Y-%m-%d %H:%M:%S", p_tm);
  9. return 0;
  10. }
int main(void)
{
    char strtime[20] = {0};
    time_t timep;
    struct tm *p_tm;
    timep = time(NULL);
    p_tm = localtime(&timep);
    strftime(strtime, sizeof(strtime), "%Y-%m-%d %H:%M:%S", p_tm);
    return 0;
}

2.9 settimeofday( )函数
头文件:#include <sys/time.h>
#include <unistd.h>
函数定义:int settimeofday(const struct timeval *tv, const struct timezone *gz);
功能描述:settimeofday( )把当前时间设成由tv指向的结构体数据。当前地区信息则设成tz指向的结构体数据。
例:
  1. int main(void)
  2. {
  3. char t_string[] = "2012-04-28 22:30:00";
  4. struct tm time_tm;
  5. struct timeval time_tv;
  6. time_t timep;
  7. int ret = 0;
  8. sscanf(t_string, "%d-%d-%d %d:%d:%d", &time_tm.tm_year, &time_tm.tm_mon, &time_tm.tm_mday, &time_tm.tm_hour, &time_tm.tm_min, &time_tm.tm_sec);
  9. time_tm.tm_year -= 1900;
  10. time_tm.tm_mon -= 1;
  11. time_tm.tm_wday = 0;
  12. time_tm.tm_yday = 0;
  13. time_tm.tm_isdst = 0;
  14. timep = mktime(&time_tm);
  15. time_tv.tv_sec = timep;
  16. time_tv.tv_usec = 0;
  17. ret = settimeofday(&time_tv, NULL);
  18. if(ret != 0)
  19. {
  20. fprintf(stderr, "settimeofday failed\n");
  21. return -1;
  22. }
  23. return 0;
  24. }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1 目标检测的定义 目标检测(Object Detection)的任务是找出图像中所有感兴趣的目标(物体),确定它们的类别和位置,是计算机视觉领域的核心问题之一。由于各类物体有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具有挑战性的问题。 目标检测任务可分为两个关键的子任务,目标定位和目标分类。首先检测图像中目标的位置(目标定位),然后给出每个目标的具体类别(目标分类)。输出结果是一个边界框(称为Bounding-box,一般形式为(x1,y1,x2,y2),表示框的左上角坐标和右下角坐标),一个置信度分数(Confidence Score),表示边界框中是否包含检测对象的概率和各个类别的概率(首先得到类别概率,经过Softmax可得到类别标签)。 1.1 Two stage方法 目前主流的基于深度学习的目标检测算法主要分为两类:Two stage和One stage。Two stage方法将目标检测过程分为两个阶段。第一个阶段是 Region Proposal 生成阶段,主要用于生成潜在的目标候选框(Bounding-box proposals)。这个阶段通常使用卷积神经网络(CNN)从输入图像中提取特征,然后通过一些技巧(如选择性搜索)来生成候选框。第二个阶段是分类和位置精修阶段,将第一个阶段生成的候选框输入到另一个 CNN 中进行分类,并根据分类结果对候选框的位置进行微调。Two stage 方法的优点是准确度较高,缺点是速度相对较慢。 常见Tow stage目标检测算法有:R-CNN系列、SPPNet等。 1.2 One stage方法 One stage方法直接利用模型提取特征值,并利用这些特征值进行目标的分类和定位,不需要生成Region Proposal。这种方法的优点是速度快,因为省略了Region Proposal生成的过程。One stage方法的缺点是准确度相对较低,因为它没有对潜在的目标进行预先筛选。 常见的One stage目标检测算法有:YOLO系列、SSD系列和RetinaNet等。 2 常见名词解释 2.1 NMS(Non-Maximum Suppression) 目标检测模型一般会给出目标的多个预测边界框,对成百上千的预测边界框都进行调整肯定是不可行的,需要对这些结果先进行一个大体的挑选。NMS称为非极大值抑制,作用是从众多预测边界框中挑选出最具代表性的结果,这样可以加快算法效率,其主要流程如下: 设定一个置信度分数阈值,将置信度分数小于阈值的直接过滤掉 将剩下框的置信度分数从大到小排序,选中值最大的框 遍历其余的框,如果和当前框的重叠面积(IOU)大于设定的阈值(一般为0.7),就将框删除(超过设定阈值,认为两个框的里面的物体属于同一个类别) 从未处理的框中继续选一个置信度分数最大的,重复上述过程,直至所有框处理完毕 2.2 IoU(Intersection over Union) 定义了两个边界框的重叠度,当预测边界框和真实边界框差异很小时,或重叠度很大时,表示模型产生的预测边界框很准确。边界框A、B的IOU计算公式为: 2.3 mAP(mean Average Precision) mAP即均值平均精度,是评估目标检测模型效果的最重要指标,这个值介于0到1之间,且越大越好。mAP是AP(Average Precision)的平均值,那么首先需要了解AP的概念。想要了解AP的概念,还要首先了解目标检测中Precision和Recall的概念。 首先我们设置置信度阈值(Confidence Threshold)和IoU阈值(一般设置为0.5,也会衡量0.75以及0.9的mAP值): 当一个预测边界框被认为是True Positive(TP)时,需要同时满足下面三个条件: Confidence Score > Confidence Threshold 预测类别匹配真实值(Ground truth)的类别 预测边界框的IoU大于设定的IoU阈值 不满足条件2或条件3,则认为是False Positive(FP)。当对应同一个真值有多个预测结果时,只有最高置信度分数的预测结果被认为是True Positive,其余被认为是False Positive。 Precision和Recall的概念如下图所示: Precision表示TP与预测边界框数量的比值 Recall表示TP与真实边界框数量的比值 改变不同的置信度阈值,可以获得多组Precision和Recall,Recall放X轴,Precision放Y轴,可以画出一个Precision-Recall曲线,简称P-R
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值