std::codecvt_mode
来自cppreference.com
在标头 <codecvt> 定义
|
||
enum codecvt_mode { consume_header = 4, |
(C++11 起) (C++17 中弃用) (C++26 中移除) |
|
刻面 std::codecvt_utf8、std::codecvt_utf16 和 std::codecvt_utf8_utf16 接受可选的 std::codecvt_mode
类型的值为模板实参,这会指定 Unicode 字符串转换的可选特性。
常量
在标头
<locale> 定义 | |
值 | 含义 |
little_endian
|
假设输入是小端序(仅应用于 UTF-16 输入,默认为大端序) |
consume_header
|
消耗可能在输入序列的开始存在的字节序标记,而且(在 UTF-16 的情况下)依赖于为解码剩下输入而指定的字节序 |
generate_header
|
在输出序列的开始输出字节序标记 |
可以辨认的字节序标记有:
0xfe 0xff
|
UTF-16 大端 |
0xff 0xfe
|
UTF-16 小端 |
0xef 0xbb 0xbf
|
UTF-8(端序无影响) |
如果在读以字节序标记开始的文件时未指定 std::consume_header
,那么将 Unicode 字符 U+FEFF(零宽无中断空格)读作字符串内容的首字符。
示例
下列示例演示消耗 UTF-8 字节序标记:
运行此代码
#include <codecvt> #include <cwchar> #include <fstream> #include <iostream> #include <locale> #include <string> int main() { // 带字节序标记的 UTF-8 数据 std::ofstream{"text.txt"} << "\ufeffz\u6c34\U0001d10b"; // 读 UTF-8 文件,跳过字节序标记 std::wifstream fin("text.txt"); fin.imbue(std::locale(fin.getloc(), new std::codecvt_utf8<wchar_t, 0x10ffff, std::consume_header>)); for (wchar_t c; fin.get(c);) std::cout << std::hex << std::showbase << c << '\n'; }
输出:
0x7a 0x6c34 0x1d10b
参阅
在字符编码间转换,包括 UTF-8、UTF-16、UTF-32 (类模板) | |
(C++11)(C++17 中弃用)(C++26 中移除) |
在 UTF-8 与 UCS-2/UCS-4 间转换 (类模板) |
(C++11)(C++17 中弃用)(C++26 中移除) |
在 UTF-16 与 UCS-2/UCS-4 间转换 (类模板) |
(C++11)(C++17 中弃用)(C++26 中移除) |
在 UTF-8 与 UTF-16 间转换 (类模板) |