- chrono[meta header]
- std::chrono[meta namespace]
- function[meta id-type]
- cpp20[meta cpp]
namespace std::chrono {
template <class charT, class traits, class Alloc = std::allocator<charT>>
std::basic_istream<charT, traits>&
from_stream(std::basic_istream<charT, traits>& is,
const charT* fmt,
month_day& md,
basic_string<charT, traits, Alloc>* abbrev = nullptr,
minutes* offset = nullptr); // (1) C++20
}フォーマット指定して入力ストリームからmonth_dayオブジェクトに入力する。
- パラメータ
fmtで指定されたフォーマットフラグを使用して、入力を解析し、mdに代入する - 有効な年の解析に失敗した場合、
is.setstate(ios_base::failbit)が呼び出され、パラメータmdは変更されない - タイムゾーンフォーマット
"%Z"が指定され、解析が成功した場合、パラメータabbrevが非ヌルである場合に*abbrevにタイムゾーン名が代入される - タイムゾーンとしてUTC時間からのオフセット時間 (日本なら
"+0900") を意味するフォーマット"%z"が指定され、解析が成功した場合、パラメータoffsetが非ヌルである場合に*offsetにその値が代入される
isを返す
#include <cassert>
#include <sstream>
#include <chrono>
namespace chrono = std::chrono;
int main()
{
{
std::stringstream ss;
ss << "Mar/1"; // "Mar/01"や"March/1"でもOK
chrono::month_day md;
chrono::from_stream(ss, md, "%b/%d");
assert(md == chrono::March/1);
}
{
std::stringstream ss;
ss << "3月1日";
chrono::month_day md;
chrono::from_stream(ss, md, "%m月%d日");
assert(md == chrono::March/1);
}
}- chrono::from_stream[color ff0000]
- chrono::March[link /reference/chrono/month_constants.md]
- C++20
- Clang: (9.0時点で実装なし)
- GCC: (9.2時点で実装なし)
- Visual C++: (2019 Update 3時点で実装なし)
- chronoの
parse()(入力フォーマットの詳細)