草庐IT

regex_iterator

全部标签

c++ - 'auto' 关键字如何知道何时使用 const_iterator 匹配函数重载?

我了解thisquestion的内容但是当使用函数重载时,事情是如何工作的呢?例如在std::map中定义了以下方法:iteratorfind(constkey_type&k);const_iteratorfind(constkey_type&k)const;如何使用auto关键字来选择一个或另一个?以下内容对我来说似乎不正确:autoi=mymap.find(key);//callsthenon-constmethod?constautoi=mymap.find(key);//callstheconstmethod? 最佳答案 s

c++ - iterator_traits中的嵌套指针类型有什么用?

std::iterator_traits类模板定义了5个嵌套类型:iterator_category,value_type,difference_type,pointer和reference.浏览的来源libc++和libstdc++的头文件,可以看到value_type的许多用途,difference_type和iterator_category,但只有一个reference(在std::iter_swap内)并且pointer没有.我的应用程序使用手工构建的代理迭代器/代理引用对。我想过渡到使用Boostiterator_facade这让我可以从默认的T&配置引用类型到任意类型,但

c++ - std::regex 和双 ABI

今天我发现了一个有趣的案例,双libstdc++ABI影响库的兼容性。长话短说,我有两个库都在内部使用std::regex。一个是使用CXX11ABI构建的,一个不是。当这两个库在一个可执行文件中链接在一起时,它会在启动时崩溃(在输入main之前)。这些库是不相关的,并且不公开提及任何std::类型的接口(interface)。我认为这样的库应该不受双重ABI问题的影响。显然不是!问题可以通过这种方式轻松重现://file.cc#includestaticstd::regexfoo("(a|b)");//main.ccintmain(){}//build.shg++-onew.ofil

C++::Boost::Regex 迭代子匹配

我将命名捕获组与BoostRegex/Xpressive结合使用。我想遍历所有子匹配,并获取每个子匹配的值和KEY(即what["type"])。sregexpattern=sregex::compile("(?Phref|src)=\"(?P[^\"]+)\"");sregex_iteratorcur(web_buffer.begin(),web_buffer.end(),pattern);sregex_iteratorend;for(;cur!=end;++cur){smatchconst&what=*cur;//Iknowhowtoaccessusingastringkey:wh

c++ - 如何在 Visual Studio 2010 中使用 std::regex 库标记字符串?

我找不到std::regex库的引用。我做了一些谷歌搜索并找到了一些教程,但它们都很简短。我不知道如何使用正则表达式标记字符串。谁能告诉我如何开始? 最佳答案 Avideotutorial在STL正则表达式上。 关于c++-如何在VisualStudio2010中使用std::regex库标记字符串?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4512269/

C++ std::regex 多行语法

我似乎无法让我的正则表达式正常工作。在ECMAScript中的多行文本中,此正则表达式begin\n([\s\S]*\nend)?完全符合我的需要,Itestedithere.当我将它翻译成C++时,它无法匹配相同的文本。这是我在VisualC++2010中的代码:#include#includeintmain(intargc,char*argv[]){std::regexmetadataBlockRegex("begin\\n([\\s\\S]*\\nend)?",std::regex::ECMAScript);std::stringtext="begin\n""123\n""end

c++ - 调整自定义迭代器以便(a?)reverse_iterator 可以翻转它的输出

最近,用户@MooingDuck设计了concatenated_range,一个优雅的自定义迭代器,解决了“链接”两个迭代器的问题,一切都在幕后。它非常适合预期用途:autorange0=concatenate_ranges(x,x+i-1,x+i,x+a5+1);a6=foo(range0.first,range0.second);现在,我想通过执行(示例#2)来调整它:autorange0=concatenate_ranges(x+a5+1,x+i-1,x+i+1,x+n);a6=foo(std::reverse_iterator(range0.second),std::rever

使用Regex拆分钻头文件

我在这里有一个文件T01X064900Y049200X065900X066900X067900X068900X069900T02X062900Y048200Y049200Y050200Y053700X063900X064900X065900X046350我要通过使用javaRegex将其读为我所做的内容,然后将其读为我读的文件内容stringparts然后String[]tools=parts.split("T\\d+");但是它不起作用,什么是最好的正格。看答案即使没有split方法,但使用捕获组:这是正则:((?

c++ - 什么时候应该使用 const_iterator 而不是 auto

下面是一个例子,我认为它说明了使用const_iterator比使用“constauto”更可取的情况。这是因为容器不提供cfind()函数。还有其他选择吗?或者应该使用“constauto”而忽略const的缺失?std::stringGetJobTitle(conststd::string&employee){usingEmployeeTitles=std::unordered_map;EmployeeTitlesemployees={{"Alice","Director"},{"Bob","Manager"},{"Charlie","Developer"}};//Option1.

c++ - std::regex 中的错误?

代码如下:#include#include#includeintmain(){std::stringpattern("[^c]ei");pattern="[[:alpha:]]*"+pattern+"[[:alpha:]]*";std::regexr(pattern);std::smatchresults;std::stringtest_str="cei";if(std::regex_search(test_str,results,r))std::cout输出:cei使用的编译器是gcc4.9.1。我是学习正则表达式的新手。我预计不会输出任何内容,因为"cei"与此处的模式不匹配。我做