std:: iscntrl
|
定义于头文件
<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
|
|
| ASCII 值 | 字符 |
iscntrl
|
|||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 十进制 | 十六进制 | 八进制 | |||||||||||||
| 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
|
<td class
|||||||||