草庐IT

STD_PROP_LIST

全部标签

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++ 编译 std::thread 示例与 scons

我无法让scons正确编译一个小型线程示例(在Linux上)。如果我运行scons,它会这样做:jarrett@jarrett-laptop:~/projects/c++_threads$sconsscons:ReadingSConscriptfiles...scons:donereadingSConscriptfiles.scons:Buildingtargets...g++-obuild/main.o-c-std=c++11-pthread-Wall-gsrc/main.cppg++-obuild/c++threadsbuild/main.oscons:donebuildingta

c++ - 为什么 std::bad_cast 被 boost::locale 抛出?

我试图了解如何使用boost::locale来比较忽略大小写和变体的字符串。我直接尝试了Boost文档中的代码:http://www.boost.org/doc/libs/1_51_0/libs/locale/doc/html/collation.htmlboost::locale::generatorgen;std::localevLocale=gen("");std::wstringa=L"Façade",b=L"facade";//Followingwillthrowbad_castbooleq=std::use_facet>(vLocale).compare(boost::lo

c++ - 如何使用 std::forward_list 在恒定时间内进行范围拼接?

我想拼接范围[first,last],包括两个端点。我有元素beforefirst和last的迭代器。我可以使用splice_after()来完成,但只能在线性时间内完成。我相信这个拼接可以在恒定时间内完成。我如何使用std::forward_list完成它?如果问题不清楚,这里是显示我的问题的示例代码:LiveWorkSpace上的代码#include#include#include#includeusingnamespacestd;intmain(){forward_listtrg{'a','b','c'};forward_listsrc{'1','2','3','4'};auto

java - Java 中 C++ 的 std::bind 是否等效?

有没有一种方法可以像在C++中使用std::bind那样将参数参数绑定(bind)到Java中的函数指针?类似这样的Java等价物是什么?voidPrintStringInt(constchar*s,intn){std::cout>funcs;funcs.push_back(std::bind(&PrintStringInt,std::placeholders::_1,4));funcs.push_back(std::bind(&PrintStringString,std::placeholders::_1,"bar"));for(autoi=funcs.begin();i!=func

c++ - 从带有原始指针的 vector 中删除 std::unique_ptr 的最佳方法?

所以我有一个像这样的vector:std::vector>myVector;然后我有另一个vector,其中包含SomeClass的原始指针:std::vectormyOtherVector;如果myOtherVector中有一个元素,它也会在myVector中,所以我想遍历myOtherVector中的每个元素并删除来自myVector的相同元素。然后清除vector。这是我想出的:for(size_ti=0;i这会产生编译时错误,因为myVector拥有唯一的指针,但我给remove()函数一个原始指针。这是我需要帮助的地方,因为我不知道解决这个问题的正确方法是什么。我将行更改为:

c++ - 如何从 std::list 实现 O(1) 删除

问题是使用std::list实现O(1)列表项删除的推荐方法是什么?通常,当我选择一个双向链表时,我希望能够在O(1)时间内从一个列表中删除一个元素,然后在O(1)时间内将它移动到另一个列表中。如果该元素有自己的prev和next指针,那么就没有真正的技巧来完成这项工作。如果列表是双向链接的循环列表,则删除不一定需要知道包含该项目的列表。根据Iteratorinvalidationrules,std::list迭代器非常耐用。因此,在我看来,在我自己的项目上使用std::list时,我想要得到的行为是在我的类和包含列表中存储一个迭代器。classItem{typedefstd::sha

c++ - std::search 是否有一个函数类似于 std::count 对 std::find 的函数?

如果标题听起来很奇怪,这里有另一种解释:如果我有一个范围a,我想计算另一个范围b在范围a中出现了多少次,是否有一个std::函数来做呢?如果不是,是否有一种简单的方法(当然我可以使用std::search手动循环-我说的是更优雅的东西)? 最佳答案 我认为您需要构建自己的。以下是我想到的实现方式。templatesize_tsubsequence_count(Iterator1haystack_begin,Iterator1haystack_end,Iterator2needle_begin,Iterator2needle_end)

c++ - 为什么 std::stoi 和 std::array 不能用 g++ c++11 编译?

过去几个月我一直在学习C++和使用终端。我的代码使用g++和C++11编译和运行良好,但在过去的几天里它开始出错,从那以后我在编译时遇到了问题。我唯一可以编译和运行的程序依赖于旧的C++标准。我首先得到的错误与头文件中的#include有关。不知道为什么会这样,但我通过使用boost/array来绕过它。我无法解决的另一个错误是std::stoi。array和stoi都应该在C++11标准库中。我编写了以下简单代码来演示发生了什么:////stoi_test.cpp////Createdbyecg//#include#include//stoishouldbeinhereintmain

c++ - 使用 std::sort 对字符串进行排序,使大写字母位于小写字母之后

我想对一个vector进行排序,使大写字母跟在小写字母之后。如果我有类似的东西ThisisatestthisisatestCatscatsthisthing我希望输出是catsCatsthisisatestThisisatestthisthing标准库排序会输出CatsThisisatestcatsthisisatestthisthing我想将谓词传递给std::sort,以便它比较我作为参数传递的字符串的小写版本。boolcompare(std::stringx,std::stringy){returnlowercase(x)我尝试降低函数中的每个字符,然后进行比较,但没有成功。我想