std::basic_regex
定义于头文件
<regex> |
||
(C++11 起) | ||
类模板 basic_regex
提供保有正则表达式的通用框架。
提供对于常见类型的几个特化:
定义于头文件
<regex> |
|
类型 | 定义 |
regex |
basic_regex<char> |
wregex |
basic_regex<wchar_t> |
成员类型
成员类型 | 定义 |
value_type |
CharT |
traits_type |
Traits |
string_type |
Traits::string_type |
locale_type |
Traits::locale_type |
flag_type |
std::regex_constants::syntax_option_type |
成员函数
构造 regex 对象 (公开成员函数) |
|
析构 regex 对象 (公开成员函数) |
|
赋值内容 (公开成员函数) |
|
赋值内容 (公开成员函数) |
|
观察器 |
|
返回正则表达式中有标记的子表达式数量 (公开成员函数) |
|
返回语法标志 (公开成员函数) |
|
本地环境 |
|
获取本地环境信息 (公开成员函数) |
|
设置本地环境信息 (公开成员函数) |
|
修改器 |
|
交换内容 (公开成员函数) |
|
常量 |
值 | 效果 |
icase |
应当以不考虑大小写进行字符匹配。 |
nosubs |
进行匹配时,将所有被标记的子表达式 (expr) 当做非标记的子表达式 (?:expr) 。不将匹配存储于提供的 std::regex_match 结构中,且 mark_count() 为零 |
optimize |
指示正则表达式引擎进行更快的匹配,带有令构造变慢的潜在开销。例如这可能表示将非确定 FSA 转换为确定 FSA 。 |
collate |
形如 "[a-b]" 的字符范围将对本地环境敏感。 |
multiline (C++17) |
若选择 ECMAScript 引擎,则指定 ^ 应该匹配行首,而 $ 应该匹配行尾。 |
ECMAScript |
使用改 ECMAScript 正则表达式文法 |
basic |
使用基本 POSIX 正则表达式文法(文法文档)。 |
extended |
使用扩展 POSIX 正则表达式文法(文法文档)。 |
awk |
使用 POSIX 中 awk 工具所用的正则表达式文法(文法文档)。 |
grep |
使用 POSIX 中 grep 工具所用的正则表达式文法。这等效于 basic 选项附带作为另一种分隔符的换行符 '\n' 。 |
egrep |
使用 POSIX 中 grep 工具带 -E 选项所用的正则表达式文法。这等效于 extended 附带 '|' 之外的作为另一种分隔符的换行符 '\n' 。 |
ECMAScript
, basic
, extended
, awk
, grep
, egrep
必须选取至多一个文法选项。若不选取文法选项,则设定为选取 ECMAScript
。其他选项作为修饰符工作,从而 std::regex("meow", std::regex::icase) 等价于 std::regex("meow", std::regex::ECMAScript|std::regex::icase)
basic_regex
中的成员常量是定义于命名空间 std::regex_constants
的 syntax_option_type 常量的副本。
非成员函数
(C++11)
|
特化 std::swap 算法 (函数模板) |