Namensräume
Varianten
Aktionen

std::isblank(std::locale)

Von cppreference.com
< cpp‎ | locale
 
 
 
 
Definiert in Header <locale>
template< class CharT >
bool isblank( CharT ch, const locale& loc );
(seit C++11)

Prüft, ob das gegebene Zeichen durch die std::ctype Facette der gegebenen Locale als Leerzeichen klassifiziert wird.

Inhalt

[bearbeiten] Parameter

ch - Zeichen
loc - locale

[bearbeiten] Rückgabewert

Gibt true zurück, wenn das Zeichen als Leerzeichen klassifiziert wird, andernfalls false.

[bearbeiten] Mögliche Implementierung

template<class CharT>
bool isblank(CharT ch, const std::locale& loc)
{
    return std::use_facet<std::ctype<CharT>>(loc).is(std::ctype_base::blank, ch);
}

[bearbeiten] Beispiel

Demonstriert die Verwendung von isblank() mit verschiedenen Locales (betriebssystemabhängig).

#include <iostream>
#include <locale>
 
void try_with(wchar_t c, const char* loc)
{
    std::wcout << "isblank('" << c << "', locale(\"" << loc << "\")) returned "
               << std::boolalpha
               << std::isblank(c, std::locale(loc)) << '\n';
}
 
int main()
{
    const wchar_t IDEO_SPACE = L'\u3000'; // Unicode character 'IDEOGRAPHIC SPACE'
    try_with(IDEO_SPACE, "C");
    try_with(IDEO_SPACE, "en_US.UTF-8");
}

Mögliche Ausgabe

isblank(' ', locale("C")) returned false
isblank(' ', locale("en_US.UTF-8")) returned true

[bearbeiten] Siehe auch

(C++11)
prüft, ob ein Zeichen ein Blank-Zeichen ist
(Funktion) [bearbeiten]
(C++11)
prüft, ob ein breites Zeichen ein Blankzeichen ist
(Funktion) [bearbeiten]