std::ctype<CharT>::scan_not, std::ctype<CharT>::do_scan_not
From cppreference.com
| ヘッダー <locale> で定義 |
||
| public: const CharT* scan_not( mask m, const CharT* beg, const CharT* end ) const; |
(1) | |
| protected: virtual const CharT* do_scan_not( mask m, const CharT* beg, const CharT* end ) const; |
(2) | |
1) 公開メンバ関数。最も派生したクラスの保護仮想メンバ関数
do_scan_notを呼び出します。2) 文字配列
[beg, end)の中で、分類マスクmを満たさない最初の文字を検索します。すなわち、is(m, c)がfalseを返すような最初の文字cを検索します。目次 |
[編集] パラメータ
| m | - | 検索するマスク |
| beg | - | 検索対象の文字配列の最初の文字へのポインタ |
| end | - | 検索対象の文字配列の終端の次のポインタ |
[編集] 戻り値
マスクを満たさない[beg, end)内の最初の文字へのポインタ。そのような文字が見つからなかった場合はend。
[編集] 例
このコードを実行
#include <clocale> #include <iostream> #include <iterator> #include <locale> int main() { std::setlocale(LC_ALL, "en_US.utf8"); std::wcout.imbue(std::locale("en_US.utf8")); auto& f = std::use_facet<std::ctype<wchar_t>>(std::wcout.getloc()); // skip leading whitespace wchar_t s1[] = L" \t\t\n Кошка"; const wchar_t* p1 = f.scan_not(std::ctype_base::space, std::begin(s1), std::end(s1)); std::wcout << '\'' << p1 << "'\n"; // skip leading digits wchar_t s2[] = L"123456789ネプネプ"; const wchar_t* p2 = f.scan_not(std::ctype_base::digit, std::begin(s2), std::end(s2)); std::wcout << '\'' << p2 << "'\n"; }
出力
'Кошка' 'ネプネプ'
[編集] 関連項目
| 分類テーブルを使用して、指定された分類に失敗するシーケンス内の最初の文字を検索します。 ( std::ctype<char>の公開メンバ関数) | |
| [virtual] |
指定された分類に準拠するシーケンス内の最初の文字を検索します。 (仮想保護メンバ関数) |