std::enable_nonlocking_formatter_optimization
来自 cppreference.cn
定义于头文件 <format> |
||
template< class T > constexpr bool enable_nonlocking_formatter_optimization = false; |
(自 C++23 起) | |
此模板可被实现使用,以启用 std::print 和 std::println 的高效实现。
如果 std::enable_nonlocking_formatter_optimization<T>
为 true,则可以更有效的方式执行类型为 T
的实参的打印(详情见 std::print)。在以下情况下,std::enable_nonlocking_formatter_optimization
特化可以是 true
-
T
是以下类型之一:std::formatter<T, CharT> 是基本标准特化 或 库类型的标准特化(见下文)。 - 程序可以为任何 cv 限定非限定的程序定义的类型
T
特化此模板。此类特化必须是可在常量表达式中使用的 且具有类型 const bool。
内容 |
[edit] 基本标准特化
在以下列表中,CharT
是 char 或 wchar_t,ArithmeticT
是任何 cv 限定非限定的算术类型,但 char、wchar_t、char8_t、char16_t 或 char32_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 |
(5) | |
template< class Traits > constexpr bool enable_nonlocking_formatter_optimization |
(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
- std::chrono::zoned_time 当其模板形参类型
TimeZonePtr
为 const std::chrono::time_zone* 时
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 相同,除了每次打印都以额外的换行符结尾 (函数模板) |