std::ctype
来自cppreference.com
                    
                                        
                    
                    
                                                            
                    |   定义于头文件  <locale>
  | 
||
|   template< class CharT > class ctype;  | 
||
类 ctype 封装字符分类特征。所有通过 std::basic_istream<charT> 进行的流输入操作用感染于流中的 std::ctype<charT> 鉴别空白符以将输入记号化。流输出操作在输出前应用 std::ctype<charT>::widen() 到窄字符参数。
继承图
标准库提供二个孤立(独立于本地环境)的特化:
|   定义于头文件  
<locale>  | |
| std::ctype<char> | 提供最小 "C" 本地环境分类的窄字符等价版本。此特化用表查找字符分类 | 
| std::ctype<wchar_t> | 提供适合于原生字符集的宽字符分类 | 
另外, C++ 程序中构造的每个 locale 对象实现其自身(本地环境限定)的这些版本。
成员类型
| 成员类型 | 定义 | 
  char_type
 | 
  CharT
 | 
成员函数
|   构造新的 ctype 平面  (公开成员函数)  | |
|   析构 ctype 平面  (受保护成员函数)  | |
  调用 do_is (公开成员函数)  | |
  调用 do_scan_is  (公开成员函数)  | |
  调用 do_scan_not (公开成员函数)  | |
  调用 do_toupper (公开成员函数)  | |
  调用 do_tolower (公开成员函数)  | |
  调用 do_widen (公开成员函数)  | |
  调用 do_narrow (公开成员函数)  | 
成员对象
|    static std::locale::id id  | 
  locale 的 id  (公开成员对象)  | 
受保护成员函数
|    [虚]  | 
  分类字符或字符序列  (虚受保护成员函数)  | 
|    [虚]  | 
  定位序列中首个符合给定分类的字符  (虚受保护成员函数)  | 
|    [虚]  | 
  定位序列中首个不符合给定分类的字符  (虚受保护成员函数)  | 
|    [虚]  | 
  转换一个或多个字符为大写  (虚受保护成员函数)  | 
|    [虚]  | 
  转换一个或多个字符为小写  (虚受保护成员函数)  | 
|    [虚]  | 
  将一或多个字符从 char 转换为 charT (虚受保护成员函数)  | 
|    [虚]  | 
  将一个或多个字符从 charT 转换为 char  (虚受保护成员函数)  | 
继承自 std::ctype_base
成员类型
| 类型 | 定义 | 
  mask
 | 
未指定的位掩码类型(枚举、整数类型或 bitset ) | 
成员常量
|    space [静态]  | 
  鉴别空白字符分类的 mask 值 (公开静态成员常量)  | 
|    print [静态]  | 
  鉴别可打印字符分类的 mask 值 (公开静态成员常量)  | 
|    cntrl [静态]  | 
  鉴别控制字符分类的 mask 值 (公开静态成员常量)  | 
|    upper [静态]  | 
  鉴别大写字符分类的 mask 值 (公开静态成员常量)  | 
|    lower [静态]  | 
  鉴别小写字符分类的 mask 值 (公开静态成员常量)  | 
|    alpha [静态]  | 
  鉴别字母字符分类的 mask 值 (公开静态成员常量)  | 
|    digit [静态]  | 
  鉴别数字字符分类的 mask 值 (公开静态成员常量)  | 
|    punct [静态]  | 
  鉴别标点字符分类的 mask 值 (公开静态成员常量)  | 
|    xdigit [静态]  | 
  鉴别十六进制数字字符分类的 mask 值 (公开静态成员常量)  | 
|    blank [静态] (C++11)  | 
  鉴别空格字符分类的 mask 值 (公开静态成员常量)  | 
|    alnum [静态]  | 
   alpha | digit   (公开静态成员常量)  | 
|    graph [静态]  | 
   alnum | punct   (公开静态成员常量)  | 
示例
下列代码演示 ctype 异于 ctype<char> 的修改,以记号化 CSV 文件
运行此代码
#include <iostream> #include <locale> #include <sstream> struct csv_whitespace : std::ctype<wchar_t> { bool do_is(mask m, char_type c) const { if ((m & space) && c == L' ') { return false; // 空格将不被分类为空白符 } if ((m & space) && c == L',') { return true; // 逗号将被分类为空白符 } return ctype::do_is(m, c); // 将剩下的留给亲类 } }; int main() { std::wstring in = L"Column 1,Column 2,Column 3\n123,456,789"; std::wstring token; std::wcout << "default locale:\n"; std::wistringstream s1(in); while (s1 >> token) { std::wcout << " " << token << '\n'; } std::wcout << "locale with modified ctype:\n"; std::wistringstream s2(in); csv_whitespace* my_ws = new csv_whitespace; // 注意:此分配不泄露 s2.imbue(std::locale(s2.getloc(), my_ws)); while (s2 >> token) { std::wcout << " " << token<< '\n'; } }
输出:
default locale: Column 1,Column 2,Column 3 123,456,789 locale with modified ctype: Column 1 Column 2 Column 3 123 456 789
参阅
|   std::ctype 对类型 char 的特化  (类模板特化)  | |
|   定义字符分类类别  (类模板)  | |
|   创建具名本地环境的 ctype 平面  (类模板)  |