std:: isspace
|
定义于头文件
<cctype>
|
||
|
int
isspace
(
int
ch
)
;
|
||
检查给定字符是否为当前安装的 C 区域设置所分类的空白字符。在默认区域设置中,空白字符包括以下内容:
-
空格 (
0x20, ' ' ) -
换页符 (
0x0c, ' \f ' ) -
换行符 (
0x0a, ' \n ' ) -
回车符 (
0x0d, ' \r ' ) -
水平制表符 (
0x09, ' \t ' ) -
垂直制表符 (
0x0b, ' \v ' )
如果 ch 的值无法表示为 unsigned char 且不等于 EOF ,则行为未定义。
目录 |
参数
| ch | - | 待分类的字符 |
返回值
若该字符为空白字符则返回非零值,否则返回零。
注释
与
<cctype>
中的所有其他函数一样,如果参数值既不能表示为
unsigned
char
也不等于
EOF
,则
std::isspace
的行为是未定义的。要安全地将这些函数用于普通
char
(或
signed
char
),应先将参数转换为
unsigned
char
:
bool my_isspace(char ch) { return std::isspace(static_cast<unsigned char>(ch)); }
同样地,当迭代器的值类型为 char 或 signed char 时,不应直接将其与标准算法一起使用。而应先将值转换为 unsigned char :
int count_spaces(const std::string& s) { return std::count_if(s.begin(), s.end(), // static_cast<int(*)(int)>(std::isspace) // 错误 // [](int c){ return std::isspace(c); } // 错误 // [](char c){ return std::isspace(c); } // 错误 [](unsigned char c){ return std::isspace(c); } // 正确 ); }
示例
#include <cctype> #include <climits> #include <iomanip> #include <iostream> int main(void) { std::cout << std::hex << std::setfill('0') << std::uppercase; for (int ch{}; ch <= UCHAR_MAX; ++ch) if (std::isspace(ch)) std::cout << std::setw(2) << ch << ' '; std::cout << '\n'; }
输出:
09 0A 0B 0C 0D 20
参见
|
检查字符是否被本地化环境分类为空白字符
(函数模板) |
|
|
检查宽字符是否为空格字符
(函数) |
|
|
C 文档
关于
isspace
|
|
| ASCII 值 | 字符 |
isspace
|
|||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 十进制 | 十六进制 | 八进制 | |||||||||||||
| 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"
|||||||||