std::basic_format_parse_context
来自cppreference.com
在标头 <format> 定义
|
||
template<class CharT> class basic_format_parse_context; |
(C++20 起) | |
提供到分析由正在分析的格式字符串范围,和自动下标参数计数组成的格式字符串分析状态的访问。
分析格式说明时,传递 basic_format_parse_context
实例给格式化器 (Formatter) 。
提供数个对于常用字符类型的 typedef:
在标头
<format> 定义 | |
类型 | 定义 |
std::format_parse_context
|
std::basic_format_parse_context<char> |
std::wformat_parse_context
|
std::basic_format_parse_context<wchar_t> |
成员类型
类型 | 定义 |
char_type
|
CharT
|
iterator
|
std::basic_string_view<CharT>::const_iterator |
const_iterator
|
std::basic_string_view<CharT>::const_iterator |
成员函数
(构造函数) |
从格式字符串和参数计数构造 std::basic_format_parse_context (公开成员函数) |
operator= [被删除] |
std::basic_format_parse_context 不可复制 (公开成员函数) |
begin |
返回指向格式字符串范围起始的迭代器 (公开成员函数) |
end |
返回指向格式字符串范围末尾的迭代器 (公开成员函数) |
advance_to |
使起始迭代器前进到给定位置 (公开成员函数) |
next_arg_id |
进入自动索引模式,并返回下一个参数下标 (公开成员函数) |
check_arg_id |
进入手动索引模式,检查给定参数下标是否在范围中 (公开成员函数) |
std::basic_format_parse_context::basic_format_parse_context
constexpr explicit basic_format_parse_context( std::basic_string_view<CharT> fmt, std::size_t num_args = 0 ) noexcept; |
(1) | |
basic_format_parse_context( const basic_format_parse_context& ) = delete; |
(2) | |
1) 构造
std::basic_format_parse_context
实例。初始化格式字符串范围为 [
fmt.begin(),
fmt.end())
,并初始化参数计数为 num_args。2) 复制构造函数被删除。
std::basic_format_parse_context
不可复制。
std::basic_format_parse_context::begin
constexpr const_iterator begin() const noexcept; |
||
返回指向格式字符串范围起始的迭代器。
std::basic_format_parse_context::end
constexpr const_iterator end() const noexcept; |
||
返回指向格式字符串范围末尾的迭代器。
std::basic_format_parse_context::advance_to
constexpr void advance_to(const_iterator it); |
||
设置格式字符串范围的起始为 it 。调用 advance_to()
后,对 begin()
的后继调用将返回 it 的副本。
如果 end() 从 it 不可及,那么行为未定义。
std::basic_format_parse_context::next_arg_id
constexpr std::size_t next_arg_id(); |
||
进入自动参数索引模式,并返回从 0 开始的下个参数下标。
如果 *this 已进入手动参数索引模式,那么就会抛出 std::format_error。
如果下个参数下标大于或等于构造函数中提供的 num_args,那么该调用不是常量表达式。
std::basic_format_parse_context::check_arg_id
constexpr void check_arg_id( std::size_t id ); |
||
进入手动参数索引模式。
如果 *this
已进入自动参数索引模式,那么就会抛出 std::format_error。
如果 id 大于或等于构造函数中提供的 num_args,那么该调用不是常量表达式。
示例
本节未完成 原因:暂无示例 |
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
---|---|---|---|
LWG 3845 | C++20 | check_arg_id 会在编译器检查 id,但 next_arg_id 不会
|
也会检查 |