• muduo Timestamp


    首先给出我学习源码时添加的注释:

    分别对应Timestamp.h Timestamp.cc文件

    // Use of this source code is governed by a BSD-style license
    // that can be found in the License file.
    //
    // Author: Shuo Chen (chenshuo at chenshuo dot com)
    
    #ifndef MUDUO_BASE_TIMESTAMP_H
    #define MUDUO_BASE_TIMESTAMP_H
    
    #include "muduo/base/copyable.h"
    #include "muduo/base/Types.h"
    
    #include <boost/operators.hpp>
    
    namespace muduo
    {
    
    ///
    /// Time stamp in UTC, in microseconds resolution.
    ///
    /// This class is immutable.
    /// It's recommended to pass it by value, since it's passed in register on x64.
    ///
    class Timestamp : public muduo::copyable,
                      public boost::equality_comparable<Timestamp>,
                      public boost::less_than_comparable<Timestamp>// 自动生成 > >= <= 
    {
     public:
      ///
      /// Constucts an invalid Timestamp.
      ///
      Timestamp()
        : microSecondsSinceEpoch_(0)
      {
      }
    
      ///
      /// Constucts a Timestamp at specific time
      ///
      /// @param microSecondsSinceEpoch
      explicit Timestamp(int64_t microSecondsSinceEpochArg)
        : microSecondsSinceEpoch_(microSecondsSinceEpochArg)
      {
      }
    
      void swap(Timestamp& that)// 交换两个Timestamp 实质是交换两者microSecondsSinceEpoch_的值
      {
        std::swap(microSecondsSinceEpoch_, that.microSecondsSinceEpoch_);
      }
    
      // default copy/assignment/dtor are Okay
    
      string toString() const;// 返回时间的字符串形式
      string toFormattedString(bool showMicroseconds = true) const;
    
      bool valid() const { return microSecondsSinceEpoch_ > 0; }// 是否为有效时间
    
      // for internal usage.
      int64_t microSecondsSinceEpoch() const { return microSecondsSinceEpoch_; }
      time_t secondsSinceEpoch() const// 返回距离1970-1-1 00:00:00的秒数
      { return static_cast<time_t>(microSecondsSinceEpoch_ / kMicroSecondsPerSecond); }
    
      ///
      /// Get time of now.
      ///
      static Timestamp now();// 获取现在时间
      static Timestamp invalid()
      {
        return Timestamp();
      }
    
      static Timestamp fromUnixTime(time_t t)
      {
        return fromUnixTime(t, 0);
      }
    
      static Timestamp fromUnixTime(time_t t, int microseconds)
      {
        return Timestamp(static_cast<int64_t>(t) * kMicroSecondsPerSecond + microseconds);
      }
    
      static const int kMicroSecondsPerSecond = 1000 * 1000;// 每秒等于多少微秒
    
     private:
      int64_t microSecondsSinceEpoch_;// 记录距离1970-1-1 00:00:00 的微秒数
    };
    
    inline bool operator<(Timestamp lhs, Timestamp rhs)// 比较两个时间
    {
      return lhs.microSecondsSinceEpoch() < rhs.microSecondsSinceEpoch();
    }
    
    inline bool operator==(Timestamp lhs, Timestamp rhs)
    {
      return lhs.microSecondsSinceEpoch() == rhs.microSecondsSinceEpoch();
    }
    
    ///
    /// Gets time difference of two timestamps, result in seconds.
    ///
    /// @param high, low
    /// @return (high-low) in seconds
    /// @c double has 52-bit precision, enough for one-microsecond
    /// resolution for next 100 years.
    inline double timeDifference(Timestamp high, Timestamp low)// 获取时间间隔单位为秒
    {
      int64_t diff = high.microSecondsSinceEpoch() - low.microSecondsSinceEpoch();
      return static_cast<double>(diff) / Timestamp::kMicroSecondsPerSecond;
    }
    
    ///
    /// Add @c seconds to given timestamp.
    ///
    /// @return timestamp+seconds as Timestamp
    ///
    inline Timestamp addTime(Timestamp timestamp, double seconds)// 从当前时间加上对应秒数
    {
      int64_t delta = static_cast<int64_t>(seconds * Timestamp::kMicroSecondsPerSecond);
      return Timestamp(timestamp.microSecondsSinceEpoch() + delta);
    }
    
    }  // namespace muduo
    
    #endif  // MUDUO_BASE_TIMESTAMP_H
    // Use of this source code is governed by a BSD-style license
    // that can be found in the License file.
    //
    // Author: Shuo Chen (chenshuo at chenshuo dot com)
    
    #include "muduo/base/Timestamp.h"
    
    #include <sys/time.h>
    #include <stdio.h>
    
    #ifndef __STDC_FORMAT_MACROS
    #define __STDC_FORMAT_MACROS
    #endif
    
    #include <inttypes.h>
    
    using namespace muduo;
    
    static_assert(sizeof(Timestamp) == sizeof(int64_t),
                  "Timestamp should be same size as int64_t");
    
    string Timestamp::toString() const
    {
      char buf[32] = {0};
      int64_t seconds = microSecondsSinceEpoch_ / kMicroSecondsPerSecond;
      int64_t microseconds = microSecondsSinceEpoch_ % kMicroSecondsPerSecond;
      snprintf(buf, sizeof(buf), "%" PRId64 ".%06" PRId64 "", seconds, microseconds);
      return buf;
    }
    
    string Timestamp::toFormattedString(bool showMicroseconds) const
    {
      char buf[64] = {0};
      time_t seconds = static_cast<time_t>(microSecondsSinceEpoch_ / kMicroSecondsPerSecond);
      struct tm tm_time;
      gmtime_r(&seconds, &tm_time);
    
      if (showMicroseconds)
      {
        int microseconds = static_cast<int>(microSecondsSinceEpoch_ % kMicroSecondsPerSecond);
        snprintf(buf, sizeof(buf), "%4d%02d%02d %02d:%02d:%02d.%06d",
                 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,
                 microseconds);
      }
      else
      {
        snprintf(buf, sizeof(buf), "%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;
    }
    
    Timestamp Timestamp::now()
    {
      struct timeval tv;
      gettimeofday(&tv, NULL);
      int64_t seconds = tv.tv_sec;
      return Timestamp(seconds * kMicroSecondsPerSecond + tv.tv_usec);
    }

    下面是测试程序,虽然用的任然是Timestamp相关代码文件,但做了相应修改,只需要包含对应的修改后的文件,而不需要安装muduo库即可运

    行测试文件,测试程序如下:

    #include <iostream>
    #include "Timestamp.h"
    #include <vector>

    int main()
    {
      muduo::Timestamp time1(muduo::Timestamp::now());
      std::cout << time1.toString() << std::endl;
      std::cout << time1.toFormattedString(true) << std::endl;
      std::cout << time1.toFormattedString(false) << std::endl;

      // 创建1000000个Timestamp个对象所需要的时间
      const int kNumber = 1000*1000;
      std::vector<muduo::Timestamp> stamps;
      stamps.reserve(kNumber);

      for (int i = 0; i < kNumber; i++) {
        stamps.push_back(muduo::Timestamp::now());
      }

      std::cout << stamps.front().toFormattedString(false) << std::endl;
      std::cout << stamps.back().toFormattedString(false) << std::endl;
      std::cout << timeDifference(stamps.back(), stamps.front()) << std::endl;

      return 0;
    }

    编译命令和输出如下:

    root@ubuntu:/home/wangml/code/muduo_test# g++ Timestamp.cc Timestamp_test.cc -o Timestamp_test
    root@ubuntu:/home/wangml/code/muduo_test# ./Timestamp_test 
    1615896149.195408
    20210316 12:02:29.195408
    20210316 12:02:29
    20210316 12:02:29
    20210316 12:02:29
    0.037397

    修改后的Timestamp以及测试文件下载:wangmlshadow/learn_muduo: 自己学习muduo源码时添加的注释以及一些自己写的测试文件 (github.com)

    转载请注明出处
  • 相关阅读:
    单点登录
    企业SOA架构案例分析
    京东峰值系统设计
    阿里搜索离线大数据平台架构
    国内不FQ使用ARCore
    Unity Android上视频使用Seek方法跳转有误差
    《搬砖日记》Obi Rope插件的简单使用
    《搬砖日记》AssetsBundle实现资源更新及通过反射添加脚本
    入园一周年
    《搬砖日记》Unity原生MicroPhone的使用
  • 原文地址:https://www.cnblogs.com/lnlin/p/14545626.html
Copyright © 2020-2023  润新知