Namespaces
Variants

std:: isspace (std::locale)

From cppreference.net
Défini dans l'en-tête <locale>
template < class CharT >
bool isspace ( CharT ch, const locale & loc ) ;

Vérifie si le caractère donné est classifié comme un caractère d'espacement par la facette std::ctype de la locale donnée.

Table des matières

Paramètres

ch - caractère
loc - paramètres régionaux

Valeur de retour

Retourne true si le caractère est classifié comme un caractère d'espacement, false sinon.

Implémentation possible

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

Exemple

Démontre l'utilisation de std::isspace() avec différentes locales (spécifiques au système d'exploitation).

#include <iostream>
#include <locale>
void try_with(wchar_t c, const char* loc)
{
    std::wcout << "isspace('" << c << "', locale(\"" << loc << "\")) returned "
               << std::boolalpha << std::isspace(c, std::locale(loc)) << '\n';
}
int main()
{
    const wchar_t EM_SPACE = L'\u2003'; // Unicode character 'EM SPACE'
    try_with(EM_SPACE, "C");
    try_with(EM_SPACE, "en_US.UTF8");
}

Sortie possible :

isspace(' ', locale("C")) returned false
isspace(' ', locale("en_US.UTF8")) returned true

Voir aussi

vérifie si un caractère est un caractère d'espacement
(fonction)
vérifie si un caractère large est un caractère d'espacement
(fonction)