std::ctype<char>::scan_is
From cppreference.com
< cpp | locale | ctype char
| ヘッダー <locale> で定義 |
||
| const char* scan_is( mask m, const char* beg, const char* end ) const; |
(1) | |
文字配列 [beg, end) の中で、指定された分類マスク m を満たす最初の文字を探します。これは、table()[(unsigned char) c] & m が true を返す最初の文字 c を意味します。
`(unsigned char)c >= std::ctype
目次 |
[編集] パラメータ
| m | - | 検索するマスク |
| beg | - | 検索対象の文字配列の最初の文字へのポインタ |
| end | - | 検索対象の文字配列の終端の次のポインタ |
[編集] 戻り値
マスクを満たす [beg, end) 内の最初の文字へのポインタ。そのような文字が見つからなかった場合は end。
[編集] 注記
プライマリテンプレート `std::ctype` とは異なり、この特殊化は文字を分類する際に仮想関数呼び出しを行いません。動作をカスタマイズするには、派生クラスが基底クラスのコンストラクタにデフォルト以外の分類テーブルを提供できます。
[編集] 例
このコードを実行
#include <iostream> #include <iterator> #include <locale> int main() { std::locale loc(""); auto& f = std::use_facet<std::ctype<char>>(loc); // skip until the first letter char s1[] = " \t\t\n Test"; const char* p1 = f.scan_is(std::ctype_base::alpha, std::begin(s1), std::end(s1)); std::cout << '\'' << p1 << "'\n"; // skip until the first letter char s2[] = "123456789abcd"; const char* p2 = f.scan_is(std::ctype_base::alpha, std::begin(s2), std::end(s2)); std::cout << '\'' << p2 << "'\n"; }
出力
'Test' 'abcd'
[編集] 関連項目
| [virtual] |
指定された分類に準拠するシーケンス内の最初の文字を検索します。 ( std::ctype<CharT> の virtual protected メンバ関数) |
| 分類テーブルを使用して、指定された分類に失敗するシーケンス内の最初の文字を検索します。 (public メンバ関数) |