std::isprint(std::locale)
Von cppreference.com
| Definiert in Header <locale> |
||
| template< class CharT > bool isprint( CharT ch, const locale& loc ); |
||
Prüft, ob das gegebene Zeichen von der std::ctype Facette der gegebenen Locale als druckbares Zeichen (einschließlich Leerzeichen) klassifiziert wird.
Inhalt |
[bearbeiten] Parameter
| ch | - | Zeichen |
| loc | - | locale |
[bearbeiten] Rückgabewert
Gibt true zurück, wenn das Zeichen als druckbar klassifiziert wird, andernfalls false.
[bearbeiten] Mögliche Implementierung
template<class CharT> bool isprint(CharT ch, const std::locale& loc) { return std::use_facet<std::ctype<CharT>>(loc).is(std::ctype_base::print, ch); } |
[bearbeiten] Beispiel
Demonstriert die Verwendung von isprint() mit verschiedenen Locales (OS-abhängig).
Führen Sie diesen Code aus
#include <iostream> #include <locale> int main() { const wchar_t c = L'\u2122'; // trademark sign std::locale loc1("C"); std::cout << "isprint('™', C locale) returned " << std::boolalpha << std::isprint(c, loc1) << '\n'; std::locale loc2("en_US.UTF-8"); std::cout << "isprint('™', Unicode locale) returned " << std::boolalpha << std::isprint(c, loc2) << '\n'; }
Mögliche Ausgabe
isprint('™', C locale) returned false
isprint('™', Unicode locale) returned true[bearbeiten] Siehe auch
| prüft, ob ein Zeichen ein druckbares Zeichen ist (Funktion) | |
| prüft, ob ein breites Zeichen ein druckbares Zeichen ist (Funktion) |