Namespaces
Variants

std:: iscntrl (std::locale)

From cppreference.net
定义于头文件 <locale>
template < class CharT >
bool iscntrl ( CharT ch, const locale & loc ) ;

检查给定字符是否被当前本地环境的 std::ctype facet 归类为控制字符。

目录

参数

ch - 字符
loc - 区域设置

返回值

若字符被分类为控制字符则返回 true ,否则返回 false

可能的实现

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

示例

演示了在不同区域设置(操作系统特定)下使用 iscntrl() 的情况。

#include <iostream>
#include <locale>
int main()
{
    const wchar_t CCH = L'\u0094'; // 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';
}

可能的输出:

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

参阅

检查字符是否为控制字符
(function)
检查宽字符是否为控制字符
(function)