正则表达式是一种用于模式匹配和搜索文本的工具。提供了一种灵活且强大的方式来查找、替换、验证和提取文本数据。
我们日常使用也经常有类似的需要。
而C++11 就有了正则,可以很方便做处理,比起使用find+substr要简单易读很多。
以下是一个简单的分割例程。
当然c++ 标准库的正则表达式实现似乎性能比较差,特别是早期版本,大文本的数据处理或者频繁的匹配最好要自行取舍性能与可读性。
自己实际使用的的另一个文本匹配解析的在几个嵌入式平台性能前后都大差不差,但是在一个交叉编译工具链版本比较低的平台产生了较大cpu占用。
#include <iostream>
#include <regex>
#include <string>
#include <vector>
int main() {
std::string input = "apple,orange,banana,grape";
std::regex pattern(",");
std::sregex_token_iterator iter(input.begin(), input.end(), pattern, -1);
std::sregex_token_iterator end;
std::vector<std::string> result(iter, end);
std::cout << "Original string: " << input << std::endl;
std::cout << "Split result:" << std::endl;
for (const auto &token : result) {
std::cout << token << std::endl;
}
return 0;
}