草庐IT

STD_PROP_LIST

全部标签

c++ - std::set<K, C>::operator<(const std::set<K, C>&) 不使用 C() 但 std::less()

无法删除我自己的问题,所以改写它... 最佳答案 这实际上不是实现中的错误,尽管它可以说是标准中的错误:23.2.1Generalcontainerrequirements[container.requirements.general]13Table98listsoperationsthatareprovidedforsometypesofcontainersbutnotothers.Thosecontainersforwhichthelistedoperationsareprovidedshallimplementtheseman

c++ - 为什么 gcc-4.9.2 不支持 std::string.insert(iterator, range) 返回迭代器

根据cppreference,C++11应该支持:templateiteratorinsert(const_iteratorpos,InputItfirst,InputItlast);但是当我尝试使用g++4.9.2编译以下代码时:std::stringstr{"helloworld"},addition{"hmy"};autoiter=str.erase(str.begin(),str.begin()+4);iter=str.insert(next(iter),addition.begin(),addition.end());//Error我收到以下错误(liveexample):e

c++ - 具有 std::unique_ptr 的容器的访问器函数

我将要设计一个API,其中存在两个类:数据/计算类和此类的容器。然而,容器不仅仅是一个哑容器,它还携带有关整个集合的信息,这超出了可以用迭代器实现的常见内容。所以,容器基本上包装了一个std::vector,添加一些预先计算的属性,实用函数等。容器类的API还应该包含的是添加data/calc类实例的方法,访问方法。我不只是想打开std::vector对公众来说,因为向容器中添加新的data/calc类会导致重新计算集合类的许多属性。但是,我想提供与STL容器访问器方法相同的访问器方法at()和operator[].最初,我添加了一个std::vector>类型的私有(private)

c++ - std::string::reserve 和字符串结尾 0

当使用std::string::reserve进行预分配时,我是否必须明确地为终止0添加one以便避免重新分配和后续复制?例如,知道长度为5的字符串"Hello"将存储在std::stringstr中,我是否必须调用str.string?保留(6)?如果我正确阅读了标准,那么我认为答案应该是是。对于reserve它说Afterreserve(),capacity()isgreaterorequaltotheargumentofreserve.对于capacity依次声明Returns:Thesizeoftheallocatedstorageinthestring.不过,我不太熟悉标准中

c++ - 为什么C++标准库中没有std::transform_n函数?

我在草稿N4431中找不到transform_n函数的提及C++标准。这是故意的吗?如果不是,人们将如何为标准的future版本提出这一建议?下面是我将如何实现它:template_OutputIteratortransform_n(_InputIterator__first,Size__n,_OutputIterator__result,_UnaryOperation__op){for(Sizei=0;i_OutputIteratortransform_n(_InputIterator1__first1,Size__n,_InputIterator2__first2,_OutputI

c++ - 我可以安全地使用#ifdef 来了解是否包含 c++ std header 吗?

首先,我读过这个问题:Isthereawaytodetectportablythatastandardheaderisincludedusingmacros?我想知道的是:使用#ifdef检测是否包含c++stdheader的安全性如何,如下面的代码所示:namespaceoverwrite{usingbyte=unsignedchar;templatevoidwithZeros(generic*toBeOverwriten,size_tlength=1){//dostuff}#ifdef_GLIBCXX_RANDOM//foundthismacroinsidetemplatevoid

c++ - 为任意类型删除实现小缓冲区优化的简单方法(如在 std::function 中)。

我倾向于使用类型删除技术。它通常看起来像这样:classYetAnotherTypeErasure{public://interfaceredirectedtopImplprivate://Adaptingfunctiontemplate...friendYetAnotherTypeErasuremake_YetAnotherTypeErasure(...);classInterface{...};templateclassConcretefinal:publicInterface{//redirectingInterfacetoAdaptee};std::unique_ptrpImp

c++ - while (std::cin >> value) 如何工作?

在C++Primer中给出的示例中,#includeusingnamespacestd;intmain(){intsum=0,value=0;while(std::cin>>value){sum+=value;//equivalenttosum=sum+value}std::cout(std::cin>>value)如何返回true?什么是“文件结尾”?看来我必须理解该术语才能理解我的主要问题。谢谢! 最佳答案 overloadedoperator>>function返回对流本身的引用,流有anoverloadedoperator这

c++ - std::map operator [] - 未定义的行为?

我一直在思考以下问题:这是否会导致未定义的行为,为什么?std::mapm;m[10]+=1;它可以完美地编译和运行,但不能证明任何事情。它类似于一个常见的UB示例i=++i+i++;因为operator[]确实有副作用,但另一方面假设任何评估顺序(从左到右从右到左)将我带到map的相同最终状态附言可能相关:http://en.cppreference.com/w/cpp/language/eval_order编辑抱歉,我应该写的m[10]=m[10]+1; 最佳答案 没有什么是未定义的。operator[]返回映射条目的左值引用(

c++ - initializer_list 返回的生命周期延长

所以我有一个返回类型为auto的lambda我在支持initializer_list的阵列方面遇到问题在这里被摧毁:constautofoo=[](constauto&a,constauto&b,constauto&c){return{a,b,c};};我将像这样使用lambda:autobar=foo(1,2,3);for(constauto&i:bar)cout我正在从事的一项工作将所有lambda表达式作为单一语句作为其编码标准的一部分(请随意表达您的愤怒。)我认为我可以通过以下方式解决这个问题:给予foovectorint的返回类型,但这搞砸了它的通用性:constautofo