std::iscntrl
來自 cppreference.com
| 在標頭檔案 <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) // wrong // [](int c){ return std::iscntrl(c); } // wrong // [](char c){ return std::iscntrl(c); } // wrong [](unsigned char c){ return std::iscntrl(c); } // correct ); }
[編輯] 示例
執行此程式碼
#include <cctype> #include <clocale> #include <iostream> int main() { unsigned char c = '\x94'; // the control code CCH in ISO-8859-1 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
|
space | 0
|
≠0
|
≠0
|
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
| 33–47 | \x21–\x2F |
\41–\57 |
!"#$%&'()*+,-./
|
0
|
≠0
|
0
|
0
|
≠0
|
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
| 48–57 | \x30–\x39 |
\60–\71 |
0123456789
|
0
|
≠0
|
0
|
0
|
≠0
|
0
|
≠0
|
0
|
0
|
0
|
≠0
|
≠0
|
| 58–64 | \x3A–\x40 |
\72–\100 |
:;<=>?@
|
0
|
≠0
|
0
|
0
|
≠0
|
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
| 65–70 | \x41–\x46 |
\101–\106 |
ABCDEF
|
0
|
≠0
|
0
|
0
|
≠0
|
0
|
≠0
|
≠0
|
≠0
|
0
|
0
|
≠0
|
| 71–90 | \x47–\x5A |
\107–\132 |
GHIJKLMNOPQRSTUVWXYZ
|
0
|
≠0
|
0
|
0
|
≠0
|
0
|
≠0
|
≠0
|
≠0
|
0
|
0
|
0
|
| 91–96 | \x5B–\x60 |
\133–\140 |
[\]^_`
|
0
|
≠0
|
0
|
0
|
≠0
|
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
| 97–102 | \x61–\x66 |
\141–\146 |
abcdef
|
0
|
≠0
|
0
|
0
|
≠0
|
0
|
≠0
|
≠0
|
0
|
≠0
|
0
|
≠0
|
| 103–122 | \x67–\x7A |
\147–\172 |
ghijklmnopqrstuvwxyz
|
0
|
≠0
|
0
|
0
|
≠0
|
0
|
≠0
|
≠0
|
0
|
≠0
|
0
|
0
|
| 123–126 | \x7B–\x7E |
\172–\176 |
{|}~
|
0
|
≠0
|
0
|
0
|
≠0
|
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
| 127 | \x7F
|
\177
|
退格字元(DEL) |
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|