名前空間
変種
操作

std::ctype<char>::scan_not

From cppreference.com
< cpp‎ | locale‎ | ctype char
 
 
 
 
 
ヘッダー <locale> で定義
const char* scan_not( mask m, const char* beg, const char* end ) const;

文字配列 [begend) の中で、分類マスク m を満たさない最初の文字を検索します。つまり、table()[(unsigned char)c] & mfalse を返す最初の文字 c を検索します。

`(unsigned char)c >= std::ctype::table_size` の場合、`table()[ (unsigned char)c ]` の代わりに、実装定義の値が代入されます。これは `c` の値によって異なる場合があります。

目次

[編集] パラメータ

m - 検索するマスク
beg - 検索対象の文字配列の最初の文字へのポインタ
end - 検索対象の文字配列の終端の次のポインタ

[編集] 戻り値

マスクを満たさない [begend) 内の最初の文字へのポインタ。そのような文字が見つからなかった場合は end

[編集] 注記

プライマリテンプレート `std::ctype` とは異なり、この特殊化は文字を分類する際に仮想関数呼び出しを行いません。動作をカスタマイズするには、派生クラスが基底クラスのコンストラクタにデフォルト以外の分類テーブルを提供できます。

[編集]

#include <iostream>
#include <iterator>
#include <locale>
 
int main()
{
    auto& f = std::use_facet<std::ctype<char>>(std::locale());
 
    // skip leading whitespace
    char s1[] = "      \t\t\n  Test";
    const char* p1 = f.scan_not(std::ctype_base::space, std::begin(s1), std::end(s1));
    std::cout << '\'' << p1 << "'\n";
 
    // skip leading digits
    char s2[] = "123456789abcd";
    const char* p2 = f.scan_not(std::ctype_base::digit, std::begin(s2), std::end(s2));
    std::cout << '\'' << p2 << "'\n";
}

出力

'Test'
'abcd'

[編集] 関連項目

[virtual]
指定された分類に失敗するシーケンス内の最初の文字を検索します
(std::ctype<CharT> の仮想保護メンバ関数) [編集]
分類テーブルを使用して、指定された分類に適合するシーケンス内の最初の文字を検索します。
(public メンバ関数) [編集]
English 日本語 中文(简体) 中文(繁體)