Namespaces
Variants

std:: iscntrl (std::locale)

From cppreference.net
Definido en el encabezado <locale>
template < class CharT >
bool iscntrl ( CharT ch, const locale & loc ) ;

Comprueba si el carácter dado está clasificado como carácter de control según la faceta std::ctype de la localización dada.

Contenidos

Parámetros

ch - carácter
loc - configuración regional

Valor de retorno

Devuelve true si el carácter se clasifica como un carácter de control, false en caso contrario.

Implementación posible

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

Ejemplo

Demuestra el uso de iscntrl() con diferentes configuraciones regionales (específicas del SO).

#include <iostream>
#include <locale>
int main()
{
    const wchar_t CCH = L'\u0094'; // Destructive Backspace in Unicode
    std::locale loc1("C");
    std::cout << "iscntrl(CCH, C locale) returned "
              << std::boolalpha << std::iscntrl(CCH, loc1) << '\n';
    std::locale loc2("en_US.UTF8");
    std::cout << "iscntrl(CCH, Unicode locale) returned "
              << std::boolalpha << std::iscntrl(CCH, loc2) << '\n';
}

Salida posible:

iscntrl(CCH, C locale) returned false
iscntrl(CCH, Unicode locale) returned true

Véase también

verifica si un carácter es un carácter de control
(función)
verifica si un carácter ancho es un carácter de control
(función)