std::ctype

< cpp‎ | locale
 
 
 
 
定义于头文件 <locale>
template< class CharT >
class ctype;

类 ctype 封装字符分类特征。所有通过 std::basic_istream<charT> 进行的流输入操作用感染于流中的 std::ctype<charT> 鉴别空白符以将输入记号化。流输出操作在输出前应用 std::ctype<charT>::widen() 到窄字符参数。

cpp/locale/ctype basecpp/locale/locale/facetstd-ctype-inheritance.svg

继承图

标准库提供二个孤立(独立于本地环境)的特化:

定义于头文件 <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 平面
(类模板)