名稱空間
變體
操作

std::range-default-formatter<std::range_format::map>

來自 cppreference.com
 
 
 
 
 
定義於標頭檔案 <format>
template< ranges::input_range R, class CharT >
struct /*range-default-formatter*/<range_format::map, R, CharT>;
(C++23 起)
(僅作說明*)

std::format_kind<R>std::range_format::map 時,類模板 /*range-default-formatter*/ 被特化用於將範圍型別格式化為鍵值對的對映。

目錄

[編輯] 成員型別

成員 定義
maybe-const-map (私有) fmt-maybe-const<R, CharT>
(僅供說明的成員型別*)
element-type (私有) std::remove_cvref_t<ranges::range_reference_t<maybe-const-map>>
(僅供說明的成員型別*)

[編輯] 資料成員

成員 定義
underlying_ (私有) 型別為 std::range_formatter<element-type, CharT> 的底層格式化器
(僅用於闡釋的成員物件*)

[編輯] 成員函式

(建構函式)
構造一個 range-default-formatter
(公開成員函式)
parse
根據 range-format-spec 指定的格式解析格式說明符
(公開成員函式)
format
根據 range-format-spec 指定的格式寫入範圍格式化輸出
(公開成員函式)

std::range-default-formatter<std::range_format::map>::range-default-formatter

constexpr /*range-default-formatter*/();

等價於
underlying_.set_brackets(STATICALLY_WIDEN<CharT>("{"), STATICALLY_WIDEN<CharT>("}"));
underlying_.underlying().set_brackets({}, {});
underlying_.underlying().set_separator(STATICALLY_WIDEN<charT>(": "));

其中 STATICALLY_WIDEN<CharT>("...")"..." 如果 CharTchar,並且是 L"..." 如果 CharTwchar_t

程式格式不正確,除非

  • element-typestd::pair 的特化,或
  • element-typestd::tuple 的特化,並且 std::tuple_size_v<element-type>2

std::range-default-formatter<std::range_format::map>::parse

template< class ParseContext >
constexpr auto parse( ParseContext& ctx ) -> ParseContext::iterator;

等價於: return underlying_.format(ctx);

返回指向 *range-format-spec* 結尾的迭代器。

std::range-default-formatter<std::range_format::map>::format

template< class FormatContext >
auto format( maybe-const-map& r, FormatContext& ctx ) const -> FormatContext::iterator;

等價於: return underlying_.format(r, ctx);

返回一個迭代器,指向輸出範圍的末尾之後。

[編輯] 另請參閱

(C++20)
定義給定型別的格式化規則
(類模板) [編輯]
有助於實現範圍型別的 std::formatter 特化的類模板
(類模板) [編輯]