std::basic_format_arg<Context>::handle
< cpp | utility | format | basic format arg
|
在标头
<format> 定义 |
||
|
template< class Context >
class basic_format_arg<Context>::handle; |
(C++20 起) | |
允许对用户定义类型的对象进行格式化的类型擦除包装器。
handle 对象常由 std::make_format_args 创建并通过 std::visit_format_arg 或 std::basic_format_arg 的 visit 成员函数 (C++26 起)访问。
数据成员
handle 的典型实现为可平凡复制 (TriviallyCopyable) 并仅存储两个非静态数据成员:
- 指向待格式化对象的 const void* 指针,以及
- 指向进行
format成员函数(见后述)所需操作的函数的 void (*)(std::basic_format_parse_context<Context::char_type>&, Context&, const void*) 函数指针。
成员函数
|
format
(C++20)
|
以给定的上下文格式化被引用的对象 (公开成员函数) |
std::basic_format_arg<Context>::handle::format
|
void format( std::basic_format_parse_context<Context::char_type>& parse_ctx,
Context& format_ctx ) const; |
(C++20 起) | |
令
T为格式化参数的类型,TD为 std::remove_const_t<T>,TQ若 const TD 满足 __formattable_with<Context> 则为 const TD,否则为TD,而ref为到格式化参数的引用。
等价于: typename Context::template formatter_type<TD> f;
parse_ctx.advance_to(f.parse(parse_ctx));
format_ctx.advance_to(f.format(const_cast<TQ&>(static_cast<const TD&>(ref)), format_ctx));
注解
handle 拥有对格式化参数的引用语义而不延长其生存期。程序员负责确保该参数存活得比 handle 更久。通常 handle 仅在格式化函数内使用。
参阅
|
(C++20)
|
提供对用户定义格式化器的格式化参数的访问的类模板 (类模板) |
|
(C++20)(C++20)
|
创建引用所有格式化参数的类型擦除对象,可转换到 format_args(函数模板) |