namespace std::chrono {
template <class charT, class traits, class Duration>
std::basic_ostream<charT, traits>&
operator<<(std::basic_ostream<charT, traits>& os, const hh_mm_ss<Duration>& hms); // (1) C++20
}
概要
hh_mm_ss
オブジェクトを出力ストリームに出力する。
戻り値
便宜上のリテラルキャストSTATICALLY-WIDEN
を導入する。STATICALLY-WIDEN<charT>("...")
は、charT
がchar
である場合は"..."
、charT
がwchar_t
である場合はL"..."
を意味する。
- (1) : 以下と等価:
return os << format(os.getloc(), STATICALLY-WIDEN<charT>("{:L%T}"), hms);
備考
- このクラスのオブジェクトを文字列フォーマットする場合、負数には先頭に
-
(マイナス) がつく
例
#include <iostream>
#include <chrono>
using std::chrono::last;
using namespace std::chrono_literals;
int main()
{
std::cout << chrono::hh_mm_ss{15h + 30min + 20s} << std::endl;
std::cout << chrono::hh_mm_ss{-(15h + 30min + 20s)} << std::endl;
std::cout << chrono::hh_mm_ss{15h + 30min + 20s + 123ms} << std::endl;
}
出力
15:30:20
-15:30:20
15:30:20.123
バージョン
言語
- C++20
処理系
- Clang: 10.0 ❌
- GCC: 10.1 ❌
- Visual C++: 2019 Update 3 ❌
関連項目
- chronoの
std::format()
(フォーマットの詳細)
参照
- LWG Issue 3262. Formatting of negative durations is not specified
- P2372R1 Fixing locale handling in chrono formatters
- この提案文書はC++20の策定後に採択されたが、実装が追いついていない時期の採択だったために、C++20の仕様として扱われる