Namespaces
Variants

std:: iscntrl

From cppreference.net
定义于头文件 <cctype>
int iscntrl ( int ch ) ;

检查给定字符是否被当前安装的 C 区域设置分类为控制字符。在默认的 "C" 区域设置中,控制字符是编码为 0x00-0x1F 0x7F 的字符。

如果 ch 的值无法表示为 unsigned char 且不等于 EOF ,则行为未定义。

目录

参数

ch - 待分类的字符

返回值

若该字符为控制字符则返回非零值,否则返回零。

注释

<cctype> 中的所有其他函数一样,若参数值既不能表示为 unsigned char 也不等于 EOF ,则 std::iscntrl 的行为是未定义的。要安全地将这些函数用于普通 char (或 signed char ),应先将参数转换为 unsigned char

bool my_iscntrl(char ch)
{
    return std::iscntrl(static_cast<unsigned char>(ch));
}

同样地,当迭代器的值类型为 char signed char 时,不应直接将其与标准算法一起使用。而应先将值转换为 unsigned char

int count_cntrls(const std::string& s)
{
    return std::count_if(s.begin(), s.end(),
                      // static_cast<int(*)(int)>(std::iscntrl)         // 错误
                      // [](int c){ return std::iscntrl(c); }           // 错误
                      // [](char c){ return std::iscntrl(c); }          // 错误
                         [](unsigned char c){ return std::iscntrl(c); } // 正确
                        );
}

示例

#include <cctype>
#include <clocale>
#include <iostream>
int main()
{
    unsigned char c = '\x94'; // ISO-8859-1 中的控制码 CCH
    std::cout << "iscntrl(\'\\x94\', default C locale) returned "
              << std::boolalpha << !!std::iscntrl(c) << '\n';
    std::setlocale(LC_ALL, "en_GB.iso88591");
    std::cout << "iscntrl(\'\\x94\', ISO-8859-1 locale) returned "
              << !!std::iscntrl(c) << '\n';
}

可能的输出:

iscntrl('\x94', default C locale) returned false
iscntrl('\x94', ISO-8859-1 locale) returned true

参见

检查字符是否被本地化环境分类为控制字符
(函数模板)
检查宽字符是否为控制字符
(函数)
C 文档 for iscntrl
<td class
ASCII 值 字符

iscntrl
iswcntrl

isprint
iswprint

isspace
iswspace

isblank
iswblank

isgraph
iswgraph

ispunct
iswpunct

isalnum
iswalnum

isalpha
iswalpha

isupper
iswupper

islower
iswlower

isdigit
iswdigit

isxdigit
iswxdigit

十进制 十六进制 八进制
0–8 \x0 \x8 \0 \10 控制码( NUL 等) ≠0 0 0 0 0 0 0 0 0 0 0 0
9 \x9 \11 制表符( \t ≠0 0 ≠0 ≠0 0 0 0 0 0 0 0 0
10–13 \xA \xD \12 \15 空白字符( \n \v \f \r ≠0 0 ≠0 0 0 0 0 0 0 0 0 0
14–31 \xE \x1F \16 \37 控制码 ≠0 0 0 0 0 0 0 0 0 0 0 0
32 \x20 \40 空格 0 ≠0 ≠0 ≠0 0 0 0 0 0 0 0 0
33–47 \x21 \x2F \41 \57 !"#$%&'()*+,-./ 0 ≠0 0