可以调用函数
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条)