std::ctype<CharT>::is, std::ctype<CharT>::do_is
来自cppreference.com
在标头 <locale> 定义
|
||
public: bool is( mask m, CharT c ) const; |
(1) | |
public: const CharT* is( const CharT* low, const CharT* high, mask* vec ) const; |
(2) | |
protected: virtual bool do_is( mask m, CharT c ) const; |
(3) | |
protected: virtual const CharT* do_is( const CharT* low, const CharT* high, mask* vec ) const; |
(4) | |
1,2) 公开成员函数,调用最终派生类的受保护虚成员函数
do_is
。3) 检查字符 c 是否以掩码 m 分类。
4) 对字符数组
[
low,
high)
中的每个字符,鉴别完整分类掩码(例如默认本地环境中对于数字 '0' 为 digit|xdigit|alnum|print|graph),并存储掩码于 vec
所指向数组的对应元素。参数
c | - | 要分类的字符 |
m | - | 用于分类单个字符的掩码 |
low | - | 指向要分类的字符数组中首字符的指针 |
high | - | 要分类的字符数组的尾后一位置指针 |
vec | - | 指向要填充的掩码数组首元素的指针 |
返回值
1,3) 若 c 以 m 分类则为 true
2,4) high
示例
运行此代码
#include <cstddef> #include <iostream> #include <locale> #include <utility> #include <vector> // 使绑定到 locale 的 facet 可析构的工具包装器 template<class Facet> struct deletable_facet : Facet { template<class ...Args> deletable_facet(Args&& ...args) : Facet(std::forward<Args>(args)...) {} ~deletable_facet() {} }; int main() { // 用默认 locale 分类单个字符 auto& f = std::use_facet<std::ctype<char>>(std::locale()); char c = '0'; if (f.is(std::ctype_base::digit, c)) // 或 isdigit(c, locale()); std::cout << '\'' << c << "' is a digit\n"; // 用具名 locale 分类每个字符串中的字符 deletable_facet<std::ctype_byname<wchar_t>> f2("en_US.utf8"); std::wstring str = L"z\u00df\u6c34\U0001d10b"; std::vector<std::ctype_base::mask> vec(str.size()); f2.is(&str[0], &str[0] + str.size(), &vec[0]); for (std::size_t n = 0; n < str.size(); ++n) { std::cout << std::hex << "U+" << static_cast<wint_t>(str[n]) << " is: "; if (vec[n] & std::ctype_base::alnum) std::cout << "alnum"; if (vec[n] & std::ctype_base::punct) std::cout << "punct"; std::cout << '\n'; } }
输出:
'0' is a digit U+7a is: alnum U+df is: alnum U+6c34 is: alnum U+1d10b is: punct
参阅
用分类表分类字符或字符序列 ( std::ctype<char> 的公开成员函数) | |
按照指定的 LC_CTYPE 类别分类宽字符 (函数) |