名前空間
変種
操作

std::ctype<CharT>::narrow, do_narrow

From cppreference.com
< cpp‎ | locale‎ | ctype
 
 
 
 
 
ヘッダー <locale> で定義
public:
char narrow( CharT c, char dflt ) const;
(1)
public:

const CharT* narrow( const CharT* beg, const CharT* end,

                     char dflt, char* dst ) const;
(2)
protected:
virtual char do_narrow( CharT c, char dflt ) const;
(3)
protected:

virtual const CharT* do_narrow( const CharT* beg, const CharT* end,

                                char dflt, char* dst ) const;
(4)
1,2) 公開メンバ関数。最派生クラスの対応する保護仮想メンバ関数do_narrowのオーバーロードを呼び出します。オーバーロード(1)はdo_narrow(c, dflt)を呼び出し、オーバーロード(2)はdo_narrow(beg, end, dflt, dst)を呼び出します。
3) (おそらくワイドな)文字cを、その文字が単一バイトで表現できる場合(例:UTF-8エンコーディングにおけるASCII文字は単一バイト)、マルチバイト表現に変換します。そのような変換が存在しない場合はdfltを返します。
4) 文字配列[begend)内の各文字について、ナローされた文字(またはナローリングに失敗した場合はdflt)を、dstが指す文字配列の連続する位置に書き込みます。

ナローリングは常に成功し、基本的なソース文字セット(C++23まで)基本的な文字セット(C++23以降) のすべての文字に対して、常に可逆的です(widen()を呼び出すことによって)。

ナローリングは、成功した場合、is()によって知られているすべての文字分類カテゴリを保持します。

  • すなわち、ctype<char>ファセットctcctype_base::maskmを持つ任意の名前付きctypeカテゴリについて、式 is(m, c) || !ctc.is(m, do_narrow(c, dflt)) は(do_narrowdfltを返す場合を除き)常に 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バイトのナロー文字にナロー化する
(関数) [編集]
English 日本語 中文(简体) 中文(繁體)