std::ctype<CharT>::narrow, do_narrow
From cppreference.com
| ヘッダー <locale> で定義 |
||
| public: char narrow( CharT c, char dflt ) const; |
(1) | |
| public: const CharT* narrow( const CharT* beg, const CharT* end, |
(2) | |
| protected: virtual char do_narrow( CharT c, char dflt ) const; |
(3) | |
| protected: virtual const CharT* do_narrow( const CharT* beg, const CharT* end, |
(4) | |
1,2) 公開メンバ関数。最派生クラスの対応する保護仮想メンバ関数
do_narrowのオーバーロードを呼び出します。オーバーロード(1)はdo_narrow(c, dflt)を呼び出し、オーバーロード(2)はdo_narrow(beg, end, dflt, dst)を呼び出します。3) (おそらくワイドな)文字
cを、その文字が単一バイトで表現できる場合(例:UTF-8エンコーディングにおけるASCII文字は単一バイト)、マルチバイト表現に変換します。そのような変換が存在しない場合はdfltを返します。4) 文字配列
[beg, end)内の各文字について、ナローされた文字(またはナローリングに失敗した場合はdflt)を、dstが指す文字配列の連続する位置に書き込みます。ナローリングは常に成功し、基本的なソース文字セット(C++23まで)基本的な文字セット(C++23以降) のすべての文字に対して、常に可逆的です(widen()を呼び出すことによって)。
- すなわち、基本的なソース文字セット(C++23まで)基本的な文字セット(C++23以降) の任意の文字
cに対して、常に do_widen(do_narrow(c, 0)) == c が成り立ちます。
ナローリングは、成功した場合、is()によって知られているすべての文字分類カテゴリを保持します。
- すなわち、
ctype<char>ファセットctcとctype_base::mask値mを持つ任意の名前付きctypeカテゴリについて、式 is(m, c) || !ctc.is(m, do_narrow(c, dflt)) は(do_narrowがdfltを返す場合を除き)常に true です。
任意の数字文字のナローリングは、結果を文字リテラル '0' から減算した場合、その差が元の文字の数字値に等しいことを保証します。
- すなわち、任意の数字文字
cについて、式 (do_narrow(c, dflt) - '0') は、その文字の数字値に評価されます。
目次 |
[編集] パラメータ
| c | - | 変換する文字 |
| dflt | - | 変換に失敗した場合に生成されるデフォルト値 |
| beg | - | 変換する文字配列の最初の文字へのポインタ |
| end | - | 変換する文字配列の終端の次を指すポインタ |
| dst | - | 埋める文字配列の最初の要素へのポインタ |
[編集] 戻り値
1,3) ナローされた文字、またはナローリングが失敗した場合は
dflt。2,4)
end[編集] 例
このコードを実行
#include <iostream> #include <locale> void try_narrow(const std::ctype<wchar_t>& f, wchar_t c) { char n = f.narrow(c, 0); if (n) std::wcout << '\'' << c << "' narrowed to " << +(unsigned char)n << '\n'; else std::wcout << '\'' << c << "' could not be narrowed\n"; } int main() { std::locale::global(std::locale("en_US.utf8")); std::wcout.imbue(std::locale()); std::wcout << std::hex << std::showbase << "In US English UTF-8 locale:\n"; auto& f = std::use_facet<std::ctype<wchar_t>>(std::locale()); try_narrow(f, L'A'); try_narrow(f, L'A'); try_narrow(f, L'ě'); std::locale::global(std::locale("cs_CZ.iso88592")); auto& f2 = std::use_facet<std::ctype<wchar_t>>(std::locale()); std::wcout << "In Czech ISO-8859-2 locale:\n"; try_narrow(f2, L'A'); try_narrow(f2, L'A'); try_narrow(f2, L'ě'); }
実行結果の例
In US English UTF-8 locale: 'A' narrowed to 0x41 'A' could not be narrowed 'ě' could not be narrowed In Czech ISO-8859-2 locale: 'A' narrowed to 0x41 'A' could not be narrowed 'ě' narrowed to 0xec
[編集] 不具合報告
以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。
| DR | 適用対象 | 公開された動作 | 正しい動作 |
|---|---|---|---|
| LWG 126 | C++98 | 1. 可逆性を示すコードは do_widen(do_narrow(c), 0) == c 2. カテゴリ保持性を示すコードは is(m, c) || !ctc.is(m, do_narrow(c), dflt) |
両方とも修正されました。 |
| LWG 153 | C++98 | narrowは常にオーバーロード(4)を呼び出していました。 |
対応するオーバーロードを呼び出します。 |
[編集] 関連項目
do_widenを呼び出します。(公開メンバ関数) | |
| 文字をナロー化する ( std::basic_ios<CharT,Traits> の public メンバ関数) | |
| 可能であれば、ワイド文字を1バイトのナロー文字にナロー化する (関数) |