[muduo网络库]——muduo库TimeStamp类(剖析muduo网络库核心部分、设计思想)

接着之前我们[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(&microSecondsSinceEpoch_);
    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

好了~ 关于muduo库的TimeStamp类就剖析到这里,它和日志类是每个类都会用到的最基本的类。下一篇我们来剖析Thread类 ~ 我们下一节见~~

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值