最近做個小東西,用到了Regex,因為用的是C++,想趕下潮流,用下boost, 開始用boost::xpressvie, 在一台HP上一切都是正常的,然後到Sun的機器上進行編譯,發現居然編譯不過,暈倒了,還好及時到boost的網站上提交報告,不然自己瞎折騰,徒是浪費時間。 目前切換到 boost::regex 模組,但是遇到一問題,發現 如下Regex ((0|1)+,?)+ 在對於00101010 比較短時,沒有問題,在001010...串很長時,直接拋出一場,哥們就不知道怎麼回事了。而用boost::xpressive
則是不知道什麼時候能否解析完成。
家裡實驗的挺快的:
#include "boost/xpressive/xpressive_dynamic.hpp"
using namespace boost::xpressive;
void test_bitmap() {
sregex reg = sregex::compile("((1|0)+,?)+");
std::string datas[] = {
"aaa-1&bbb-0&ccc-1",
"1111000111",
"11001010,101100100101010010101",
"1001010010101100110010101010101001010,10101010",
"100101001010110011001010101010100101010101010"};
for (int i = 0; i < sizeof(datas) / sizeof(std::string); ++i) {
std::cout << "match result:" << regex_match(datas[i], reg) << ", data:" << datas[i] << std::endl;
}
}
int main() {
cregex reg = cregex::compile("(\\s*\\d+\\s*|(\\[|\\()\\s*\\d+\\s*,\\s*\\d+\\s*(\\]|\\)))(\\s*,\\s*(\\s*\\d+\\s*|(\\[|\\()\\s*\\d+\\s*,\\s*\\d+\\s*(\\]|\\))))*");
std::cout << regex_match("[ 10 ,100),1, 8", reg);
test_bitmap();
return 0;
}