std::enable_nonlocking_formatter_optimization

来自cppreference.com
< cpp‎ | utility‎ | format
 
 
工具库
语言支持
类型支持(基本类型、RTTI)
库功能特性测试宏 (C++20)
动态内存管理
程序工具
协程支持 (C++20)
变参数函数
调试支持
(C++26)
三路比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)

 
 
在标头 <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

基本的标准特化

以下列表中,CharTcharwchar_tArithmeticT 是除了 charwchar_tchar8_tchar16_tchar32_t 之外的任何无 cv 限定的算术类型:

字符格式化器对应的无锁标志
template<>
inline constexpr bool enable_nonlocking_formatter_optimization<CharT> = true;
(1)
字符串格式化器对应的无锁标志
template<>
inline constexpr bool enable_nonlocking_formatter_optimization<CharT*> = true;
(2)
template<>
inline 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<>
inline constexpr bool enable_nonlocking_formatter_optimization<ArithmeticT> = true;
(7)
指针格式化器对应的无锁标志
template<>
inline constexpr bool enable_nonlocking_formatter_optimization<std::nullptr_t> = true;
(8)
template<>
inline constexpr bool enable_nonlocking_formatter_optimization<void*> = true;
(9)
template<>
inline constexpr bool enable_nonlocking_formatter_optimization<const void*> = true;
(10)

库类型的标准特化

enable_nonlocking_formatter_optimization 针对下列标准模板的所有特化的特化均被定义为 true

enable_nonlocking_formatter_optimization 针对下列标准模板的所有特化的特化均被定义为根据条件为 true

enable_nonlocking_formatter_optimization 针对范围格式种类并非 std::range_format::disabled 的所有可格式化范围类型的特化总是被定义为 false

注解

功能特性测试 标准 功能特性
__cpp_lib_print 202403L (C++26)
(DR23)
进行流锁定的格式化输出
202406L (C++26)
(DR23)
启用更多可格式化类型的非锁定格式化器优化

参阅

(C++20)
定义针对给定类型的格式化规则
(类模板)
(C++23)
将参数的格式化表达输出到 stdout 或文件缓冲区
(函数模板)
(C++23)
将参数的格式化表达输出到 stdout 或文件缓冲区,输出完成后换行
(函数模板)