Namensräume
Varianten
Aktionen

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

Von cppreference.com
< cpp‎ | locale‎ | ctype
 
 
 
 
 
Definiert in Header <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) Öffentliche Member-Funktion, ruft die geschützte virtuelle Member-Funktion do_is der am weitesten abgeleiteten Klasse auf.
3) Prüft, ob das Zeichen c durch die Maske m klassifiziert wird.
4) Identifiziert für jedes Zeichen im Zeichenarray [lowhigh) die vollständige Klassifizierungsmaske (z. B. digit|xdigit|alnum|print|graph für die Ziffer '0' in der Standard-Locale) und speichert die Masken in den entsprechenden Elementen des Arrays, auf das vec zeigt.

Inhalt

[edit] Parameter

c - zu klassifizierendes Zeichen
m - Maske zur Klassifizierung eines einzelnen Zeichens
low - Zeiger auf das erste Zeichen in einem zu klassifizierenden Zeichenarray
high - Zeiger auf das Ende des zu klassifizierenden Zeichenarrays (exklusiv)
vec - Zeiger auf das erste Element des zu füllenden Maskenarrays

[edit] Rückgabewert

1,3) true, wenn c durch m klassifiziert wird.
2,4) high

[edit] Beispiel

#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';
    }
}

Ausgabe

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

[edit] Siehe auch

klassifiziert ein Zeichen oder eine Zeichensequenz unter Verwendung der Klassifizierungstabelle
(öffentliche Member-Funktion von std::ctype<char>) [edit]
klassifiziert ein breites Zeichen gemäß der angegebenen LC_CTYPE-Kategorie
(Funktion) [bearbeiten]