現在のタイムスタンプを取得する方法
最初にstd::chrono
現在のシステム時間を取得するために使用し、次に現在のシステム時間をエポック時間std::time_t
タイプに変換し、次にペア タイプを使用してstd::localtime
ローカルstd::time_t
時間構造std::tm
タイプに変換し、最後にstrftime
ペア時間を使用して出力をフォーマットします。
このstd::tm
構造には、次の部分に分割されたカレンダー時間が含まれています。
struct tm {
int tm_sec; // 秒,范围从 0 到 59
int tm_min; // 分,范围从 0 到 59
int tm_hour; // 小时,范围从 0 到 23
int tm_mday; // 一月中的第几天,范围从 1 到 31
int tm_mon; // 月份,范围从 0 到 11
int tm_year; // 自 1900 起的年数
int tm_wday; // 一周中的第几天,范围从 0 到 6
int tm_yday; // 一年中的第几天,范围从 0 到 365
int tm_isdst; // 夏令时
};
このsize_t strftime(char *str, size_t maxsize, const char *format, const struct tm *timeptr)
関数は、format で定義されたフォーマット規則に従って、構造体 timeptr で表される時刻をフォーマットし、str に格納します。
size_t strftime(char *str, size_t maxsize, const char *format, const struct tm *timeptr)
関数パラメータ
- str - 結果の C 文字列がコピーされる宛先配列へのポインタです。
- maxsize - str にコピーされる最大文字数です。
- format – これは、通常の文字と特殊な形式指定子の任意の組み合わせを含む C 文字列です。
これらの書式指定子は、tm で指定された時間を表す対応する値を持つ関数に置き換えられます。特定の書式指定子は次のとおりです。
フォーマット指定子 | 意義 | 例 |
---|---|---|
%a | 曜日の短縮名 | 太陽 |
%A | 完全な曜日名 | 日曜日 |
%b | 月の短縮名 | 3月 |
%B | 完全な月名 | 行進 |
%c | 日付と時刻の表現 | 2012 年 8 月 19 日(日)02:56:02 |
%C | 西暦の上の 2 桁 | |
%d | 月の日 (01-31) | 19 |
%D | 月日年 | |
%e | 2 文字フィールドの 10 進数の日付 | |
%F | 年月日 | |
%g | 西暦の下 2 桁 (週ベースの年を使用) | |
%G | 年、週ベースの年を使用 | |
%h | 月の短縮名 | |
%H | 24 時間形式の時間 (00 ~ 23) | 14 |
%私 | 12 時間形式の時間 (01 ~ 12) | 05 |
%j | 年間の日 (001-366) | 231 |
%m | 10 進数での月 (01 ~ 12) | 08 |
%M | ポイント (00-59) | 55 |
%p | 午前または午後の名前 | 午後 |
%r | 12時間 | |
%R | 時と分を表示: hh:mm | |
%S | 秒 (00-61) | 02 |
%t | 水平タブ | |
%T | 時、分、秒を表示: hh:mm:ss | |
%u | 曜日、月曜日が最初の日(値は1~7、月曜日が1) | |
%U | 第 1 日曜日を第 1 週の初日とする年間の週 (00 ~ 53) | 33 |
%V | 年間の週、週ベースの年を使用 | |
%w | 曜日は 10 進数で表され、日曜日は 0 (0 ~ 6) で表されます。 | 4 |
%W | 第 1 月曜日を第 1 週の初日とする年間の週 (00 ~ 53) | 34 |
%バツ | 日付表現 | 12/08/19 |
%バツ | 時間表現 | 02:50:06 |
%y | 年、下 2 桁 (00 ~ 99) | 01 |
%Y | 年 | 2012年 |
%Z | タイムゾーンの名前または略語 | CDT |
%% | サイン | % |
現在のタイムスタンプ関数を取得する
現在のタイムスタンプを取得する関数は次のとおりです。関数の形式は次のとおりです。
std::string GetCurrentTimeStamp(int time_stamp_type = 0)
関数パラメータ
- time_stamp_type - 取得するタイムスタンプのレベル。0 は秒レベルのタイムスタンプを表し、1 はミリ秒レベルのタイムスタンプを表し、2 はマイクロ秒レベルのタイムスタンプを表し、3 はナノ秒レベルのタイムスタンプを表します。
関数の戻り値は、現在のタイムスタンプ文字列を返します。
この機能の使用例は次のとおりです。
#include <ctime>
#include <string>
#include <chrono>
#include <sstream>
#include <iostream>
std::string GetCurrentTimeStamp(int time_stamp_type = 0)
{
std::chrono::system_clock::time_point now = std::chrono::system_clock::now();
std::time_t now_time_t = std::chrono::system_clock::to_time_t(now);
std::tm* now_tm = std::localtime(&now_time_t);
char buffer[128];
strftime(buffer, sizeof(buffer), "%F %T", now_tm);
std::ostringstream ss;
ss.fill('0');
std::chrono::milliseconds ms;
std::chrono::microseconds cs;
std::chrono::nanoseconds ns;
switch (time_stamp_type)
{
case 0:
ss << buffer;
break;
case 1:
ms = std::chrono::duration_cast<std::chrono::milliseconds>(now.time_since_epoch()) % 1000;
ss << buffer << ":" << ms.count();
break;
case 2:
ms = std::chrono::duration_cast<std::chrono::milliseconds>(now.time_since_epoch()) % 1000;
cs = std::chrono::duration_cast<std::chrono::microseconds>(now.time_since_epoch()) % 1000000;
ss << buffer << ":" << ms.count() << ":" << cs.count() % 1000;
break;
case 3:
ms = std::chrono::duration_cast<std::chrono::milliseconds>(now.time_since_epoch()) % 1000;
cs = std::chrono::duration_cast<std::chrono::microseconds>(now.time_since_epoch()) % 1000000;
ns = std::chrono::duration_cast<std::chrono::nanoseconds>(now.time_since_epoch()) % 1000000000;
ss << buffer << ":" << ms.count() << ":" << cs.count() % 1000 << ":" << ns.count() % 1000;
break;
default:
ss << buffer;
break;
}
return ss.str();
}
int main()
{
std::cout << GetCurrentTimeStamp(0) << std::endl;
std::cout << GetCurrentTimeStamp(1) << std::endl;
std::cout << GetCurrentTimeStamp(2) << std::endl;
std::cout << GetCurrentTimeStamp(3) << std::endl;
return 0;
}
結果出力:
2022-05-27 14:35:58
2022-05-27 14:35:58:879
2022-05-27 14:35:58:879:200
2022-05-27 14:35:58:879:200 :100