std:: isprint
|
定义于头文件
<cctype>
|
||
|
int
isprint
(
int
ch
)
;
|
||
检查 ch 是否被当前安装的 C 区域设置分类为可打印字符。在默认的 "C" 区域设置中,以下字符是可打印的:
-
数字 (
0123456789) -
大写字母 (
ABCDEFGHIJKLMNOPQRSTUVWXYZ) -
小写字母 (
abcdefghijklmnopqrstuvwxyz) -
标点符号 (
!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~) -
空格 (
)
如果 ch 的值无法表示为 unsigned char 且不等于 EOF ,则行为未定义。
目录 |
参数
| ch | - | 待分类的字符 |
返回值
若字符可打印则返回非零值,否则返回零。
注释
与
<cctype>
中的所有其他函数一样,如果参数值既不能表示为
unsigned
char
也不等于
EOF
,则
std::isprint
的行为是未定义的。要安全地将这些函数用于普通
char
(或
signed
char
),应首先将参数转换为
unsigned
char
:
bool my_isprint(char ch) { return std::isprint(static_cast<unsigned char>(ch)); }
同样地,当迭代器的值类型为 char 或 signed char 时,不应直接将其与标准算法一起使用。而应先将值转换为 unsigned char :
int count_prints(const std::string& s) { return std::count_if(s.begin(), s.end(), // static_cast<int(*)(int)>(std::isprint) // 错误 // [](int c){ return std::isprint(c); } // 错误 // [](char c){ return std::isprint(c); } // 错误 [](unsigned char c){ return std::isprint(c); } // 正确 ); }
示例
#include <cctype> #include <clocale> #include <iostream> int main() { unsigned char c = '\xa0'; // ISO-8859-1 中的非换行空格 std::cout << "isprint(\'\\xa0\', default C locale) returned " << std::boolalpha << (bool)std::isprint(c) << '\n'; std::setlocale(LC_ALL, "en_GB.iso88591"); std::cout << "isprint(\'\\xa0\', ISO-8859-1 locale) returned " << std::boolalpha << (bool)std::isprint(c) << '\n'; }
可能的输出:
isprint('\xa0', default C locale) returned false
isprint('\xa0', ISO-8859-1 locale) returned true
参见
|
检查字符是否被本地化环境分类为可打印字符
(函数模板) |
|
|
检查宽字符是否为打印字符
(函数) |
|
|
C 文档
关于
isprint
|
|
| ASCII 值 | 字符 |
isprint
|
|||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 十进制 | 十六进制 | 八进制 | |||||||||||||
| 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="table-no
|||||||||