std::wstring_convert<Codecvt,Elem,Wide_alloc,Byte_alloc>::converted
提供: cppreference.com
<tbody>
</tbody>
| ヘッダ <locale> で定義
|
||
std::size_t converted() const noexcept; |
||
最も最近の from_bytes() または to_bytes() によって処理されたソース文字の数を返します。
戻り値
最も最近の変換操作によって消費された文字数。
例
Run this code
#include <iostream>
#include <string>
#include <locale>
#include <codecvt>
int main()
{
std::string utf8 = u8"z\u00df\u6c34\U0001d10b"; // or u8"zß水𝄋"
// or "\x7a\xc3\x9f\xe6\xb0\xb4\xf0\x9d\x84\x8b";
std::cout << "original UTF-8 string size: " << utf8.size() << '\n';
// the UTF-8 - UTF-32 standard conversion facet
std::wstring_convert<std::codecvt_utf8<char32_t>, char32_t> cvt;
// UTF-8 to UTF-32
std::u32string utf32 = cvt.from_bytes(utf8);
std::cout << "UTF-32 string size: " << utf32.size() << '\n';
std::cout << "converted() == " << cvt.converted() << '\n';
// UTF-32 to UTF-8
utf8 = cvt.to_bytes(utf32);
std::cout << "new UTF-8 string size: " << utf8.size() << '\n';
std::cout << "converted() == " << cvt.converted() << '\n';
}
出力:
original UTF-8 string size: 10
UTF-32 string size: 4
converted() == 10
new UTF-8 string size: 10
converted() == 4
欠陥報告
以下の動作変更欠陥報告は以前に発行された C++ 標準に遡って適用されました。
| DR | 適用先 | 発行時の動作 | 正しい動作 |
|---|---|---|---|
| LWG 2174 | C++11 | wstring_convert::converted was not required to be noexcept
|
required |
関連項目
| ワイド文字列をバイト文字列に変換します (パブリックメンバ関数) | |
| バイト文字列をワイド文字列に変換します (パブリックメンバ関数) |