Namespaces
Variants

std::wstring_convert<Codecvt,Elem,Wide_alloc,Byte_alloc>:: converted

From cppreference.net
定义于头文件 <locale>
std:: size_t converted ( ) const noexcept ;

返回最近一次 from_bytes() to_bytes() 成功处理的源字符数量。

目录

返回值

cvtcount

示例

#include <codecvt>
#include <iostream>
#include <locale>
#include <string>
int main()
{
    std::string utf8 = "z\u00df\u6c34\U0001d10b"; // 或 u8"zß水𝄋"
                   // 或 "\x7a\xc3\x9f\xe6\xb0\xb4\xf0\x9d\x84\x8b";
    std::cout << "原始 UTF-8 字符串大小: " << utf8.size() << '\n';
    // UTF-8 到 UTF-32 标准转换 facet
    std::wstring_convert<std::codecvt_utf8<char32_t>, char32_t> cvt;
    // UTF-8 到 UTF-32
    std::u32string utf32 = cvt.from_bytes(utf8);
    std::cout << "UTF-32 字符串大小: " << utf32.size() << '\n';
    std::cout << "converted() == " << cvt.converted() << '\n';
    // UTF-32 到 UTF-8
    utf8 = cvt.to_bytes(utf32);
    std::cout << "新 UTF-8 字符串大小: " << utf8.size() << '\n';
    std::cout << "converted() == " << cvt.converted() << '\n';
}

输出:

原始 UTF-8 字符串大小: 10
UTF-32 字符串大小: 4
converted() == 10
新 UTF-8 字符串大小: 10
converted() == 4

缺陷报告

下列行为变更缺陷报告被追溯应用于先前发布的 C++ 标准。

缺陷报告 应用于 发布时的行为 正确行为
LWG 2174 C++11 wstring_convert::converted 未被要求为 noexcept 要求为 noexcept

参见

将宽字符串转换为字节字符串
(公开成员函数)
将字节字符串转换为宽字符串
(公开成员函数)