命名空间
变体
操作

std::enable_nonlocking_formatter_optimization

来自 cppreference.cn
< cpp‎ | utility‎ | format
 
 
 
 
定义于头文件 <format>
template< class T >
constexpr bool enable_nonlocking_formatter_optimization = false;
(自 C++23 起)

此模板可被实现使用,以启用 std::printstd::println 的高效实现。

如果 std::enable_nonlocking_formatter_optimization<T>true,则可以更有效的方式执行类型为 T 的实参的打印(详情见 std::print)。在以下情况下,std::enable_nonlocking_formatter_optimization 特化可以是 true

内容

[edit] 基本标准特化

在以下列表中,CharTcharwchar_tArithmeticT 是任何 cv 限定非限定的算术类型,但 charwchar_tchar8_tchar16_tchar32_t 除外

字符格式器的非锁定标志
template<>
constexpr bool enable_nonlocking_formatter_optimization<CharT> = true;
(1)
字符串格式器的非锁定标志
template<>
constexpr bool enable_nonlocking_formatter_optimization<CharT*> = true;
(2)
template<>
constexpr bool enable_nonlocking_formatter_optimization<const CharT*> = true;
(3)
template< std::size_t N >
constexpr bool enable_nonlocking_formatter_optimization<CharT[N]> = true;
(4)
template< class Traits, class Alloc >

constexpr bool enable_nonlocking_formatter_optimization

    <std::basic_string<CharT, Traits, Alloc>> = true;
(5)
template< class Traits >

constexpr bool enable_nonlocking_formatter_optimization

    <std::basic_string_view<CharT, Traits>> = true;
(6)
算术格式器的非锁定标志
template<>
constexpr bool enable_nonlocking_formatter_optimization<ArithmeticT> = true;
(7)
指针格式器的非锁定标志
template<>
constexpr bool enable_nonlocking_formatter_optimization<std::nullptr_t> = true;
(8)
template<>
constexpr bool enable_nonlocking_formatter_optimization<void*> = true;
(9)
template<>
constexpr bool enable_nonlocking_formatter_optimization<const void*> = true;
(10)

[edit] 库类型的标准特化

enable_nonlocking_formatter_optimization 对于以下标准模板的所有特化均定义为 true

enable_nonlocking_formatter_optimization 对于以下标准模板的所有特化均有条件地定义为 true

对于所有可格式化的范围类型enable_nonlocking_formatter_optimization 的特化始终定义为 false,其中范围格式种类不是 std::range_format::disabled

[edit] 注解

特性测试 Std 特性
__cpp_lib_print 202403L (C++26)
(DR23)
带流锁定的格式化输出
202406L (C++26)
(DR23)
为更多可格式化类型启用非锁定格式器优化

[edit] 参见

(C++20)
为给定类型定义格式化规则
(类模板) [编辑]
(C++23)
使用实参的格式化表示形式打印到 stdout 或文件流
(函数模板) [编辑]
(C++23)
std::print 相同,除了每次打印都以额外的换行符结尾
(函数模板) [编辑]