接着之前我们[muduo网络库]——muduo库logger类(剖析muduo网络库核心部分、设计思想),我们接下来继续看muduo库中的TimeStamp类,这也是每一个类几乎都能用到的非常简单的类。
TimeStamp类
Timestamp类主要用于日志、定时器模块中记录时间戳、打印时间戳字符串等
重要成员变量
int64_t microSecondsSinceEpoch_;
成员变量microSecondsSinceEpoch_
,用来来表示从 Epoch (1970年一月一日凌晨零点零分零秒) 时间到目前为止的微妙数,初值0(也表示无效值)。microSecondsSinceEpoch_
的数据类型int64_t,可以表示290余年的微妙数,其范围满足目前日常需求。而有符号的int64_t可以用来让2个时间戳进行差值计算,从而表示先后顺序。
重要成员函数
- 获取时间
TimeStamp TimeStamp::now()
{
return TimeStamp(time(NULL)); //获取当前时间
}
调用系统time()
函数,返回自纪元 Epoch 起经过的时间,以秒为单位。
- 类型转变
Timestamp::toString()
std::string TimeStamp::toString() const
{
char buf[128]={0};
tm *tm_time = localtime(µSecondsSinceEpoch_);
snprintf(buf, 128, "%4d/%02d/%02d %02d:%02d:%02d",
tm_time->tm_year+1900,
tm_time->tm_mon+1,
tm_time->tm_mday,
tm_time->tm_hour,
tm_time->tm_min,
tm_time->tm_sec);
return buf;
}
struct tm *localtime(const time_t *timer) 使用 timer 的值来填充 tm 结构。timer 的值被分解为 tm 结构,并用本地时区表示。其中tm_xxxx
,对应着
int tm_sec; /* Seconds. [0-60] (1 leap second) */
int tm_min; /* Minutes. [0-59] */
int tm_hour; /* Hours. [0-23] */
int tm_mday; /* Day. [1-31] */
int tm_mon; /* Month. [0-11] */
int tm_year; /* Year - 1900. */
int tm_wday; /* Day of week. [0-6] */
int tm_yday; /* Days in year.[0-365] */
int tm_isdst; /* DST. [-1/0/1]*/
对这些变量,加一定的值,就得到了我们想要的时间。
简单测试一下:
#include <iostream>
int main()
{
std::cout<<TimeStamp::now().toString()<<std::endl;
return 0;
}
代码地址:https://github.com/Cheeron955/mymuduo/tree/master