std::ispunct

来自cppreference.com
< cpp‎ | string‎ | byte
在标头 <cctype> 定义
int ispunct(int ch );

检查给定的字符是否被当前 C 本地环境分类为标点字符。默认 C 本地环境分类字符(!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~)为标点。

ch 的值不能表示为 unsignedchar 且不等于 EOF 则行为未定义。

目录

[编辑]参数

ch - 要分类的字符

[编辑]返回值

若字符为标点字符则为非零值,否则为零。

[编辑]注解

同所有其他来自 <cctype> 的函数,若实参值既不能表示为 unsignedchar 又不等于 EOFstd::ispunct 的行为未定义。为了以单纯的 char(或 signedchar)安全使用此函数,首先要将实参转换为 unsignedchar

bool my_ispunct(char ch){return std::ispunct(static_cast<unsignedchar>(ch));}

类似地,迭代器的值类型为 charsignedchar 时,不应直接将它们用于标准算法。而是要首先转换值为 unsignedchar

int count_puncts(conststd::string& s){returnstd::count_if(s.begin(), s.end(), // static_cast<int(*)(int)>(std::ispunct) // 错误// [](int c){ return std::ispunct(c); } // 错误// [](char c){ return std::ispunct(c); } // 错误[](unsignedchar c){return std::ispunct(c);}// 正确);}

[编辑]示例

#include <cctype>#include <clocale>#include <iostream>   int main(){unsignedchar c ='\xd7';// ISO-8859-1 中的字符 × (乘号)   std::cout<<"ispunct(\'\\xd7\', 默认 C 本地环境) 返回 "<<std::boolalpha<<(bool)std::ispunct(c)<<'\n';   std::setlocale(LC_ALL, "en_GB.iso88591");std::cout<<"ispunct(\'\\xd7\', ISO-8859-1 本地环境) 返回 "<<std::boolalpha<<(bool)std::ispunct(c)<<'\n';}

可能的输出:

ispunct('\xd7', 默认 C 本地环境) 返回 false ispunct('\xd7', ISO-8859-1 本地环境) 返回 true

[编辑]参阅

检查字符是否被本地环境分类为标点
(函数模板)[编辑]
检查宽字符是否为标点字符
(函数)[编辑]
ispunct 的 C 文档
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 等) ≠000000000000
9 \x9\11 制表 (\t) ≠00≠0≠000000000
10–13 \xA\xD\12\15 空白符 (\n, \v, \f, \r) ≠00≠0000000000
14–31 \xE\x1F\16\37 控制码 ≠000000000000
32 \x20\40 space 0≠0≠0≠000000000
33–47 \x21\x2F\41\57!"#$%&'()*+,-./0≠000≠0≠0000000
48–57 \x30\x39\60\7101234567890≠000≠00≠0000≠0≠0
58–64 \x3A\x40\72\100:;<=>?@0≠000≠0≠0000000
65–70 \x41\x46\101\106ABCDEF0≠000≠00≠0≠0≠000≠0
71–90 \x47\x5A\107\132GHIJKLMNOP
QRSTUVWXYZ
0≠000≠00≠0≠0≠0000
91–96 \x5B\x60\133\140[\]^_`0≠000≠0≠0000000
97–102 \x61\x66\141\146abcdef0≠000≠00≠0≠00≠00≠0
103–122 \x67\x7A\147\172ghijklmnop
qrstuvwxyz
0≠000≠00≠0≠00≠000
123–126 \x7B\x7E\172\176{|}~0≠000≠0≠0000000
127 \x7F\177 退格字符 (DEL) ≠000000000000
close