std::codecvt<InternT,ExternT,StateT>::length, do_length

来自cppreference.com
< cpp‎ | locale‎ | codecvt
 
 
 
 
在标头 <locale> 定义
public:

int length( StateT& state, const ExternT* from, const ExternT* from_end,

            std::size_t max ) const;
(1)
protected:

virtual int do_length( StateT& state, const ExternT* from, const ExternT* from_end,

                       std::size_t max ) const;
(2)
1) 公开成员函数,调用最终派生类的成员函数 do_length
2) 给定初始转换状态 state,尝试将来自 [fromfrom_end) 定义的字符数组的 ExternT 字符,转换到最多 maxInternT 字符,并返回这种转换会消耗的 ExternT 字符数。如同以对某虚构的 [to, to + max) 输出缓冲区执行 do_in(state, from, from_end, from, to, to + max, to) 一般修改 state

返回值

假如以 do_in() 转换直至消耗所有 from_end - from 个字符,或产生 maxInternT 字符,或出现转换错误时,消耗的 ExternT 字符数。

无转换特化 std::codecvt<char, char, std::mbstate_t> 返回 std::min(max, from_end - from)

示例

#include <iostream>
#include <locale>
#include <string>
 
int main()
{
    using facet_type = std::codecvt<wchar_t, char, std::mbstate_t>;
 
    // 窄多字节编码
    std::string s = "z\u00df\u6c34\U0001d10b"; // 或 u8"zß水𝄋"
              // 或 "\x7a\xc3\x9f\xe6\xb0\xb4\xf0\x9d\x84\x8b";
 
    std::setlocale(LC_ALL, "en_US.UTF-8");
    facet_type const& codecvt_facet = std::use_facet<facet_type>(std::locale());
    std::mbstate_t mb = std::mbstate_t();
    std::cout << s.size() << " 个字节中只有开头的 "
              << codecvt_facet.length(mb, &s[0], &s[s.size()], 2)
              << " 个字节会被消耗,以产生开头的 2 个字符\n";
}

输出:

10 个字节中只有开头的 3 个字节会被消耗,以产生开头的 2 个字符

缺陷报告

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

缺陷报告 应用于 出版时的行为 正确行为
LWG 75 C++98 未指明对 state 的影响 已指明
LWG 305 C++98 std::codecvt<char, char, std::mbstate_t>::do_length
要求返回 std::min(max, from_end - from)
不再要求

参阅

[虚]
将字符串从 ExternT 转换到 InternT,例如在从文件读取时
(虚受保护成员函数)