名前空間
変種
操作

std::codecvt_utf16

提供: cppreference.com
< cpp‎ | locale
 
 
 
ヘッダ <codecvt> で定義
template<class Elem,

          unsignedlong Maxcode =0x10ffff,
          std::codecvt_mode Mode =(std::codecvt_mode)0>

class codecvt_utf16 :publicstd::codecvt<Elem, char, std::mbstate_t>;
(C++11以上)
(C++17で非推奨)

std::codecvt_utf16 は UTF-16 エンコードされたバイト文字列と UCS2 または UTF-32 文字列 (Elem の型によります) の間の変換をカプセル化する std::codecvt ファセットです。 この codecvt ファセットはバイナリモードで UTF-16 ファイルを読み書きするために使用できます。

目次

[編集]テンプレート引数

Elem - char16_tchar32_t または wchar_t のいずれか
Maxcode - このファセットがエラーなしに読み書きする Elem の最も大きな値
Mode - std::codecvt_mode 型の定数

[編集]メンバ関数

コンストラクタ
新しい codecvt_utf16 ファセットを構築します
(パブリックメンバ関数)
デストラクタ
codecvt_utf16 ファセットを破棄します
(パブリックメンバ関数)

std::codecvt_utf16::codecvt_utf16

explicit codecvt_utf16(std::size_t refs =0);

新しい std::codecvt_utf16 ファセットを構築し、初期参照カウンタ refs を基底クラスに渡します。

引数

refs - ファセットにリンクする参照の数

std::codecvt_utf16::~codecvt_utf16

~codecvt_utf16();

ファセットを破棄します。 ロケール管理のファセットと異なり、このファセットのデストラクタはパブリックです。

std::codecvt から継承

メンバ型

メンバ型 定義
intern_typeinternT
extern_typeexternT
state_typestateT

メンバオブジェクト

メンバ名
id(static)std::locale::id

メンバ関数

do_out を呼びます
(std::codecvt<InternT,ExternT,State>のパブリックメンバ関数)[edit]
do_in を呼びます
(std::codecvt<InternT,ExternT,State>のパブリックメンバ関数)[edit]
do_unshift を呼びます
(std::codecvt<InternT,ExternT,State>のパブリックメンバ関数)[edit]
do_encoding を呼びます
(std::codecvt<InternT,ExternT,State>のパブリックメンバ関数)[edit]
do_always_noconv を呼びます
(std::codecvt<InternT,ExternT,State>のパブリックメンバ関数)[edit]
do_length を呼びます
(std::codecvt<InternT,ExternT,State>のパブリックメンバ関数)[edit]
do_max_length を呼びます
(std::codecvt<InternT,ExternT,State>のパブリックメンバ関数)[edit]

プロテクテッドメンバ関数

[仮想]
ファイルを書き込む時などのために、文字列を internT から externT に変換します
(std::codecvt<InternT,ExternT,State>の仮想プロテクテッドメンバ関数)[edit]
[仮想]
ファイルから読み込む時などのために、文字列を externT から internT に変換します
(std::codecvt<InternT,ExternT,State>の仮想プロテクテッドメンバ関数)[edit]
[仮想]
不完全な変換に対する externT 文字の終了文字シーケンスを生成します
(std::codecvt<InternT,ExternT,State>の仮想プロテクテッドメンバ関数)[edit]
[仮想]
一定であれば、ひとつの internT 文字を生成するのに必要な externT の文字数を返します
(std::codecvt<InternT,ExternT,State>の仮想プロテクテッドメンバ関数)[edit]
ファセットがすべての有効な引数の値に対して恒等変換をエンコードするかどうか調べます
(std::codecvt<InternT,ExternT,State>の仮想プロテクテッドメンバ関数)[edit]
[仮想]
与えられた internT バッファへの変換によって消費されるであろう externT 文字列の長さを計算します
(std::codecvt<InternT,ExternT,State>の仮想プロテクテッドメンバ関数)[edit]
単一の internT 文字に変換される可能性のある externT の最大文字数を返します
(std::codecvt<InternT,ExternT,State>の仮想プロテクテッドメンバ関数)[edit]


std::codecvt_base から継承

メンバ型 定義
enum result { ok, partial, error, noconv }; スコープなし列挙型
列挙定数 定義
ok 変換はエラーなしで完了しました
partial 変換元の文字は全部は変換されませんでした
error 無効な文字に遭遇しました
noconv 変換は必要ありません、入力と出力の型は同じです

[編集]ノート

標準は、 Elem のサイズが16ビットのときはこのファセットが UCS2 で動作することを要求していますが、一部の処理系は代わりに UTF-16 を使用し、これを無変換ファセットとしています。 用語「UCS2」は非推奨であり、 Unicode 標準からは削除されました。

[編集]

以下の例は32ビット wchar_t のシステムで UTF-16LE ファイルのデコードをデモンストレーションします。 16ビット wchar_t のシステムでは、 std::codecvt_utf16<char16_t> が UTF-16 でなく UCS2 を生成するため、3文字目のデコードに失敗します。

#include <fstream>#include <iostream>#include <string>#include <locale>#include <codecvt>   void prepare_file(){// UTF-16le data (if host system is little-endian)char16_t utf16le[4]={0x007a, // latin small letter 'z' U+007a0x6c34, // CJK ideograph "water" U+6c340xd834, 0xdd0b};// musical sign segno U+1d10b// store in a filestd::ofstream fout("text.txt"); fout.write(reinterpret_cast<char*>(utf16le), sizeof utf16le);}   int main(){ prepare_file();// open as a byte streamstd::wifstream fin("text.txt", std::ios::binary);// apply facet fin.imbue(std::locale(fin.getloc(), new std::codecvt_utf16<wchar_t, 0x10ffff, std::little_endian>));   for(wchar_t c; fin.get(c);)std::cout<<std::showbase<<std::hex<< c <<'\n';}

出力:

0x7a 0x6c34 0x1d10b

[編集]関連項目

文字変換 ロケール定義のマルチバイト
(UTF-8, GB18030)
UTF-8
UTF-16
UTF-16 mbrtoc16 / c16rtomb(C11のDR488あり)codecvt<char16_t, char, mbstate_t>
codecvt_utf8_utf16<char16_t>
codecvt_utf8_utf16<char32_t>
codecvt_utf8_utf16<wchar_t>
N/A
UCS2 c16rtomb(C11のDR488なし)codecvt_utf8<char16_t>

codecvt_utf8<wchar_t>(Windows)

codecvt_utf16<char16_t>

codecvt_utf16<wchar_t>(Windows)

UTF-32

mbrtoc32 / c32rtomb

codecvt<char32_t, char, mbstate_t>
codecvt_utf8<char32_t>
codecvt_utf8<wchar_t>(Windows以外)

codecvt_utf16<char32_t>
codecvt_utf16<wchar_t>(Windows以外)

システム全体:
UTF-32(Windows以外)
UCS2(Windows)

mbsrtowcs / wcsrtombs
use_facet<codecvt
<wchar_t, char, mbstate_t>>(locale)

No No
UTF-8, UTF-16, UTF-32 を含む文字エンコーディング間の変換を行います
(クラステンプレート)[edit]
(C++11)(C++17で非推奨)
標準の codecvt ファセットの動作を変更するためのタグ
(列挙)[edit]
(C++11)(C++17で非推奨)
UTF-8 と UCS2/UCS4 の間で変換を行います
(クラステンプレート)[edit]
(C++11)(C++17で非推奨)
UTF-8 と UTF-16 の間で変換を行います
(クラステンプレート)[edit]
close