Namespaces
Variants

std::ctype<CharT>:: is, std::ctype<CharT>:: do_is

From cppreference.net
ヘッダーで定義 <locale>
public :
bool is ( mask m, CharT c ) const ;
(1)
public :
const CharT * is ( const CharT * low, const CharT * high, mask * vec ) const ;
(2)
protected :
virtual bool do_is ( mask m, CharT c ) const ;
(3)
protected :
virtual const CharT * do_is ( const CharT * low, const CharT * high, mask * vec ) const ;
(4)
1,2) パブリックメンバー関数。最も派生したクラスの保護された仮想メンバー関数 do_is を呼び出す。
3) 文字 c がマスク m によって分類されるかどうかをチェックします。
4) 文字配列内の各文字について [ low , high ) の範囲で、完全な分類マスク(例えばデフォルトロケールにおける数字 '0' に対する digit | xdigit | alnum | print | graph )を識別し、そのマスクを vec が指す配列の対応する要素に格納します。

目次

パラメータ

c - 分類対象の文字
m - 単一文字の分類に使用するマスク
low - 分類対象の文字配列の先頭文字へのポインタ
high - 分類対象の文字配列の終端(末尾の次)を指すポインタ
vec - マスク配列の先頭要素へのポインタ

戻り値

1,3) true c m によって分類される場合。
2,4) high

#include <cstddef>
#include <iostream>
#include <locale>
#include <utility>
#include <vector>
// ロケールに束縛されたファセットを破棄可能にするユーティリティラッパー
template<class Facet>
struct deletable_facet : Facet
{
    template<class ...Args>
    deletable_facet(Args&& ...args) : Facet(std::forward<Args>(args)...) {}
    ~deletable_facet() {}
};
int main()
{
    // デフォルトロケールを使用して単一文字を分類
    auto& f = std::use_facet<std::ctype<char>>(std::locale());
    char c = '0';
    if (f.is(std::ctype_base::digit, c)) // または isdigit(c, locale());
        std::cout << '\'' << c << "' is a digit\n";
    // 名前付きロケールを使用して文字列内のすべての文字を分類
    deletable_facet<std::ctype_byname<wchar_t>> f2("en_US.utf8");
    std::wstring str = L"z\u00df\u6c34\U0001d10b";
    std::vector<std::ctype_base::mask> vec(str.size());
    f2.is(&str[0], &str[0] + str.size(), &vec[0]);
    for (std::size_t n = 0; n < str.size(); ++n)
    {
        std::cout << std::hex << "U+" << static_cast<wint_t>(str[n]) << " is: ";
        if (vec[n] & std::ctype_base::alnum) 
            std::cout << "alnum";
        if (vec[n] & std::ctype_base::punct) 
            std::cout << "punct";
        std::cout << '\n';
    }
}

出力:

'0' is a digit
U+7a is: alnum 
U+df is: alnum 
U+6c34 is: alnum 
U+1d10b is: punct

関連項目

文字または文字シーケンスを分類テーブルを使用して分類する
( std::ctype <char> の公開メンバー関数)
指定された LC_CTYPE カテゴリに従ってワイド文字を分類する
(関数)