
linxu上有提供相应的c语言的接口
比如time函数
使用time函数可以获取一个时间戳
该时间戳是1870年1月1日0:0:0至现在的秒数
然后我们可以使用linux提供的一些转换接口将其转换为时分秒的格式
比如ctime或者也可以使用gmtime或者localtime将其转换为struct tm结构体的数据
我们同样也可以使用gettimeofday函数来获取时间
比如一个简单的代码实现如下
#include <stdio.h>#include <time.h>
#include <string.h>
int main(int argc,char **argv)
{
time_t t
struct tm *m
if((t=time(NULL)) == (time_t)-1)
{
perror("time")
return -1
}
m=localtime(&t)
printf("%.2d:%.2d:%.2d\n",m->tm_hour,m->tm_min,m->tm_sec)
return 0
}
可以调用函数
settimeofday
int settimeofday(const struct timeval *tv , const struct timezone *tz)struct timeval {
time_t tv_sec /* seconds since Jan. 1, 1970 */
suseconds_t tv_usec /* 微妙 */
}
也可以用system调用系统命令date
没有完整程序, 不过能提供一点资料int gettimeofday(struct timeval * tv,struct timezone *tz)
这个函数可以获取当前时间, 貌似只要第一个结构体就行了
struct timeval
{
time_t tv_sec//秒 [long int]
suseconds_t tv_usec//微秒 [long int], (10E-6 second)
}
struct timeval
{
long tv_sec
long tv_usec
}
然后取微秒的前三位就是小数了, 之后把秒 tv_sec 转化为 tm 格式, 参数用秒的指针就行
struct tm * gmtime(const time_t * t)
//转换成格林威治时间。有时称为GMT或UTC。
struct tm * localtime(const time_t *t)
//转换成本地时间。它可以透过修改TZ环境变数来在一台机器中,不同使用者表示不同时间.
下面是tm的部分参数
int tm_sec//tm_sec表「秒」数,在[0,61]之间,多出来的两秒是用来处理跳秒问题用的。/* Seconds: 0-59 (K&R says 0-61?) */
int tm_min//tm_min表「分」数,在[0,59]之间。
int tm_hour//tm_hour表「时」数,在[0,23]之间。
int tm_mday//tm_mday表「本月第几日」,在[1,31]之间。
int tm_mon//tm_mon表「本年第几月」,在[0,11]之间。
int tm_year//tm_year要加1900表示那一年。 /* /* 年份,其值从1900开始 */*/
int tm_wday//tm_wday表「本周第几日」,在[0,6]之间。 /* Days since Sunday (0-6) */ /*其中0代表星期天,1代表星期一,以此类推 */
int tm_yday//tm_yday表「本年第几日」,在[0,365]之间,闰年有366日。 /*其中0代表1月1日,1代表1月2日,以此类推 */*/
int tm_isdst//tm_isdst表是否为「日光节约时间」
------------------------------华丽丽的分割线--------------------------------------------------
由于很长时间没编程了, 也没有Linux环境, 我就简单写几行代码, 仅作参考
#include <stdio.h>
#include <time.h>
#include <sys/time.h>
#include<unistd.h>
//这四个不一定够用了
struct timeval tv
struct timezone tz
struct tm * p_tm
//变量没有初始化习惯不好,不要学
gettimeofday(&tv, &tz)
p_tm = gmtime( (const time_t *)&tv.tv_sec )
字符串的组装尤其格式问题自己解决吧
年 p_tm->tm_year+ 1900
月 p_tm->tm_mon+ 1
日 p_tm->tm_mday
时 p_tm->tm_hour+ 1
分 p_tm->tm_min+ 1
秒 p_tm->tm_sec+ 1
小数点后面的部分,注意不够三位还是前面填充0 tv.tv_sec/1000
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)