C++ 具名要求:字符特征 (CharTraits)

来自cppreference.com
< cpp‎ | named req


 
 
C++ 具名要求
 

字符特征 (CharTraits) 是特征类,它抽象给定字符类型的基本字符和字符串操作。大多数标准库字符串类和输入/输出类要求伴随字符模板类型形参的对应字符特征 (CharTraits) 模板类型形参。

要求

字符特征 (CharTraits) 上的下列操作均不可抛出异常。

给定

  • CharT,字符类型
  • XCharT字符特征 (CharTraits) 类型
  • cdCharT 类型的值
  • pqconst CharT* 类型的值
  • sCharT* 类型的值
  • nijstd::size_t 类型的值
  • efX::int_type 类型的值
  • posX::pos_type 类型的值
  • stateX::state_type 类型的值
  • rCharT 类型的左值

类型

类型 语义
X::char_type CharT
X::int_type 能保有 X::char_type 的所有合法值外加 X::eof() 的类型
X::off_type X 为输入/输出类中的特征模板形参时,如果此类型不是 std::streamoff 会引起实现定义行为。
X::pos_type
  • 输入/输出类中的函数返回此类型,以 X::pos_type(X::off_type(-1)) 为提示错误的无效值
  • 以此类型的无效值作为接收此类型的值的 std::istreamstd::ostreamstd::streambuf 的任何成员的实参都是未定义行为
  • 在以 X 为输入/输出类中的特性模板形参时,如果此类型不是 std::streampos 会引起实现定义行为
X::state_type  可析构 (Destructible) 可复制赋值 (CopyAssignable) 可复制构造 (CopyConstructible) 可默认构造 (DefaultConstructible)

表达式

表达式 返回类型 语义  复杂度 
X::eq(c, d) bool 返回:是否把 c 当做等于 d 常数
X::lt(c, d) bool 返回:是否把 c 当做小于 d 常数
X::compare(p, q, n) int 返回:
  • 0,如果对 [0n) 中的每个 iX::eq(p[i], q[i]) 都是 true
  • 否则为负值,如果
    • [0n) 中的某个 jX::lt(p[j], q[j])true,且
    • [0j) 中的每个 iX::eq(p[i], q[i]) 都是 true
  • 否则为正值
线性
X::length(p) std::size_t 返回:使得 X::eq(p[i], CharT())true 的最小 i 线性
X::find(p, n, c) const X::char_type* 返回:
  • [pp + n) 中使得 X::eq(*q, c)true 的最小 q
  • 否则为 0
线性
X::move(s, p, n) X::char_type*
  • [0n) 中的每个 i 进行 X::assign(s[i], p[i])
  • 即使范围 [pp + n)[ss + n) 重叠也能正确复制
  • 返回:s
线性
X::copy(s, p, n) X::char_type*
  • 要求:[pp + n)[ss + n) 不重叠
  • 返回:s
  • [0n) 中的每个 i 进行 X::assign(s[i], p[i])
线性
X::assign(r, d) (不使用) 赋值 r = d 常数
X::assign(s, n, c) X::char_type*
  • [0n) 中的每个 i 进行 X::assign(s[i], c)
  • 返回:s
线性
X::not_eof(e) X::int_type 返回:
  • e,如果 X::eq_int_type(e, X::eof())false
  • 否则为使得 X::eq_int_type(f, X::eof())false 的值 f
常数
X::to_char_type(e) X::char_type 返回:
  • 如果 X::eq_int_type(e, X::to_int_type(c)) 对某个 ctrue 则为 c
  • 否则为某个未指定值
常数
X::to_int_type(c) X::int_type 返回:X::to_char_typeX::eq_int_type 的定义所制约的某个值 e 常数
X::eq_int_type(e, f) bool
  • 对于所有 cdX::eq(c, d) 等于 X::eq_int_type(X::to_int_type(c),
                   X::to_int_type(d))
  • 返回:
    • X::eq(c, d),如果对于某 cde == X::to_int_type(c)f == X::to_int_type(d)
    • 否则为 true,如果 ef 都是 X::eof() 的副本
    • 否则为 false,如果 ef 之一是 X::eof() 的副本而另一者不是
    • 否则值未指定
常数
X::eof() X::int_type 返回:使得 X::eq_int_type(e, X::to_int_type(c)) 对于所有值 c 都是 false 的值 e 常数

标准库

下列标准库类模板要求字符特征 (CharTraits) 作为模板类型形参:

字符串
存储并操作字符序列
(类模板)
只读的字符串视图
(类模板)
管理任意流缓冲
(类模板)
包装给定的抽象设备(std::basic_streambuf
并提供高层输入接口
(类模板)
实现高层文件流输入操作
(类模板)
实现高层字符串流输入操作
(类模板)
实现固定字符缓冲区输入操作
(类模板)
包装给定的抽象设备(std::basic_streambuf
并提供高层输出接口
(类模板)
实现高层文件流输出操作
(类模板)
实现高层字符串流输出操作
(类模板)
同步输出流的包装
(类模板)
实现固定字符缓冲区输出操作
(类模板)
包装给定的抽象设备(std::basic_streambuf
并提供高层输入/输出接口
(类模板)
实现高层文件流输入/输出操作
(类模板)
实现高层字符串流输入/输出操作
(类模板)
实现固定字符缓冲区输入/输出操作
(类模板)
流迭代器
std::basic_istream 读取的输入迭代器
(类模板)
写入 std::basic_ostream 的输出迭代器
(类模板)
流缓冲
抽象原生设备
(类模板)
实现原生文件设备
(类模板)
实现原生字符串设备
(类模板)
同步输出设备的包装器
(类模板)
实现原始固定字符缓冲区设备
(类模板)
流缓冲迭代器
std::basic_streambuf 读取的输入迭代器
(类模板)
写入 std::basic_streambuf 的输出迭代器
(类模板)


下列标准库 std::char_traits 显式特化满足字符特征 (CharTraits)

template<> class char_traits<char>;

template<> class char_traits<wchar_t>;
template<> class char_traits<char8_t>;
template<> class char_traits<char16_t>;

template<> class char_traits<char32_t>;


(C++20 起)
(C++11 起)
(C++11 起)

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 335 C++98 assign 的二元重载的要求没有禁止向右值赋值 第一个参数只能是左值
LWG 352 C++98 X::state_type 只需要
可复制构造 (CopyConstructible)
也需要 可复制赋值 (CopyAssignable)
可默认构造 (DefaultConstructible)
LWG 3085 C++98 X::copy(s, p, n) 只要求 p
不在 [ss + n) 中,过于宽松[1]
要求 [pp + n)
[ss + n) 不重叠
  1. [pp + n)[ss + n) 可以重叠,此时使用 std::memcpy 实现 X::copy 的话行为未定义。