time.h
time()
time_t time(time_t *calptr);
返回1970-1-1, 00:00:00以来经过的秒数
结果可以通过返回值,也可以通过参数得到,见实例
返回值:
成功:秒数,从1970-1-1,00:00:00 可以当成整型输出或用于其它函数
失败:-1
例:
time_t now;//time_t 本质是long long类型的数据(%lld)
time(&now);// 等价于: now = time(NULL)
printf("now time is %d\n", now);
localtime()
struct tm localtime(const time_t calptr);
将时间数值变换成本地时间,考虑到本地时区和夏令时标志;
返回值:
成功: 返回struct tm *结构体指针, 原型如下:
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日 */
int tm_isdst; /* 夏令时标识符,夏令时tm_isdst为正;不实行夏令时tm_isdst为0 */
};
注意: 内核自动创建了一个struct tm结构体变量, 我们只需要定义struct tm*指针即可, 也不需要我们去释放这个结构体变量
失败: NULL
例:
time_t now ;
struct tm *tm_now ;
time(&now) ;
tm_now = localtime(&now) ;
printf("now datetime: %d-%d-%d %d:%d:%d\n", tm_now->tm_year+1900, tm_now->tm_mon+1, tm_now->tm_mday, tm_now->tm_hour, tm_now->tm_min, tm_now->tm_sec) ;
具体操作函数
包含文件:<sys/time.h> <time.h>
struct tm *gmtime(time_t * t);//与localtime()基本相同.
char *asctime(const struct tm *timeptr);//格式: "Wed Jun 30 21:49:08 1993\n"
char *ctime(const time_t *timer); //格式: "Wed Jun 30 21:49:08 1993\n"
把tm指针转换为time_t
time_t mktime(struct tm *timeptr);
localtime和gmtime的区别在于gmtime将时间转换为国际标准格式,也就是相对于1970 00:00:00开始的时间戳
而localtime是相对于本地的时区的格式。
#include<stdio.h>
#include<time.h>
#include<sys/time.h>
#include<signal.h>
#include<pthread.h>
void quit_t()
{
printf("eixt now");
exit(-1);
}
int main()
{
/* struct timeval vt;
gettimeofday(&vt , NULL);
while(1)
{
printf("%u:%u\n",vt.tv_sec,vt.tv_usec);
sleep(2);
signal(SIGINT, quit_t);
}
*/
struct tm *tt;
time_t t = time(NULL);
tt = gmtime(&t);
//char *s = asctime(tt);
printf("%d-%d-%d %d:%d:%d",tt->tm_year+1900,tt->tm_mon+1,tt->tm_mday,tt->tm_hour,tt->tm_min,tt->tm_sec);
return 0;
}