Namespaces
Variants

std:: isprint (std::locale)

From cppreference.net
헤더 파일에 정의됨 <locale>
template < class CharT >
bool isprint ( CharT ch, const locale & loc ) ;

주어진 문자가 주어진 로캘의 std::ctype 패싯에 의해 출력 가능한 문자(공백 포함)로 분류되는지 확인합니다.

목차

매개변수

ch - 문자
loc - 로케일

반환값

해당 문자가 출력 가능한 것으로 분류되면 true 를 반환하고, 그렇지 않으면 false 를 반환합니다.

가능한 구현

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);
}

예제

다양한 로케일(OS별)에서 isprint() 사용법을 보여줍니다.

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

가능한 출력:

isprint('™', C locale) returned false
isprint('™', Unicode locale) returned true

참고 항목

문자가 출력 가능한 문자인지 확인합니다
(함수)
와이드 문자가 출력 가능한 문자인지 확인합니다
(함수)