std::ctype<CharT>::is, std::ctype<CharT>::do_is
From cppreference.com
| ヘッダー <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) Public member function、最も派生したクラスのprotected virtualメンバ関数
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> // utility wrapper to make locale-bound facets destructible template<class Facet> struct deletable_facet : Facet { template<class ...Args> deletable_facet(Args&& ...args) : Facet(std::forward<Args>(args)...) {} ~deletable_facet() {} }; int main() { // classify a single character using the default locale auto& f = std::use_facet<std::ctype<char>>(std::locale()); char c = '0'; if (f.is(std::ctype_base::digit, c)) // or isdigit(c, locale()); std::cout << '\'' << c << "' is a digit\n"; // classify every character in a string using a named locale 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>のpublic member function) | |
指定されたLC_CTYPEカテゴリに従ってワイド文字を分類する(関数) |