C++ STL 正则表达式 非常的慢

2021/6/21 14:28:53

本文主要是介绍C++ STL 正则表达式 非常的慢,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

如题 同样给的正则表达式,同样的测试文本,stl正则速度很慢,目前解决办法是用boost的正则表达式后速度提升不少 代码如下

// header file
#include <boost\regex.hpp> 
//
static boost::wregex expression(L"[a-zA-Z_0-9-]+(\\.[a-zA-Z0-9-]+)*@([a-zA-Z0-9])+(\\.[a-zA-Z0-9-]+)+");
	//boost::wsmatch what;

	wstring::iterator start = str_in.begin();
	wstring::iterator end = str_in.end();
	boost::match_results<wstring::iterator> what;
	//boost::wsmatch
	boost::match_flag_type flags = boost::match_default;

	//bool b = boost::regex_search(str_in, what, expression);
    // exist exception
	try
	{
		while (boost::regex_search(start, end, what, expression, flags))
		{
			//if (what[0].matched)
			//{
			vStr_out.push_back(what[0]);
			//}
			// update search position:
			start = what[0].second;
			// update flags: 
			flags |= boost::match_prev_avail;
			flags |= boost::match_not_bob;
		}
	}
	catch (CMemoryException* e)
	{
		return;
	}
	catch (CFileException* e)
	{
		return;
	}
	catch (boost::exception& e)
	{
		return;
	}

 



这篇关于C++ STL 正则表达式 非常的慢的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程