草庐IT

pairing_iterator

全部标签

c++ - boost::transform_iterator 不适用于 std::bind( &Pair::first, _1 )?

通过std::map的键集进行迭代的传统任务将我引向了另一个似乎尚未在此处讨论的困惑局面。简而言之,这段代码无法编译(大量使用C++11):typedefstd::pairPair;vectorv{Pair(1,2),Pair(2,3)};usingnamespacestd::placeholders;autochoose_first=std::bind(&Pair::first,_1);boost::make_transform_iterator(v.begin(),choose_first);错误信息如下。notypenamed'result_type'in'structstd::

c++ 范围的排序 View - 如何创建 const_iterator?

我正在尝试编写一个类,该类应充当某些基础元素序列的排序View。到目前为止,我提出了一个非const版本。现在我在调整它以提供const_iterator功能时遇到了问题。我目前的代码如下所示://forwarddeclareiteratortemplateclasssorted_range_iter;templateclasssorted_range{friendclasssorted_range_iter;private:usingT=typenameInputIt::value_type;InputIt_first;InputIt_last;std::vector_indices

c++ - 为什么 *_iterators 在移除 std::iterator 后仍然需要 typedef something void?

我使用ostreambuf_iterator如下图:在c++17之前,template>classostreambuf_iterator:publicstd::iterator要求我们确定std::iterator的每个参数类型,因此,对于std::ostreambuf_iterator,void还不错。据我们所知,std::iterator在c++17中已弃用。因此,迭代器应该在它们自己的主体中对它们的成员类型进行typedef,例如:MembertypeDefinition---------------------------------------------value_type

c++ - std::make_pair 与 C++11 统一初始值设定项

使用后者有缺点吗?std::make_pair是更通用/更兼容还是它们真的可以互换?谢谢! 最佳答案 它们有什么关系?使用初始化列表构造函数不适用于一对,因为pair是异构类型的,而初始化列表构造函数使用initializer_list,它仅可用于检索同类类型的初始化列表。(查看规范,它真的应该称为“初始化列表构造函数”,而不是“初始化列表构造函数”。你真的是指第一个吗?如果不是,你指的是什么?)。如果你只是指初始化一个std::pair使用初始化列表反对使用std::make_pair并使用auto,我觉得两者都可以。autop=

c++ - 如何复制 boost::filesystem::directory_iterator?

我知道这听起来很愚蠢,但看看这个简单的例子(工作目录应该有多个项目):#defineBOOST_FILESYSTEM_VERSION3#include#includeintmain(){usingnamespaceboost::filesystem;directory_iteratorit("./");directory_iteratorit_copy=it;++it;assert(it_copy!=it);return0;}it_copy是和it一起修改的!(boost1.45)什么样的考虑会导致这样的设计(directory_iterator类似于smartptr)?我只需要保存一

C++ 无法将 lambda 转换为 std::pair 中的 std::packaged_task

我用std::packaged_task做了一些测试遇到了这个问题。std::packaged_tasktask([]()->int{return1;});task();编译和调用task()调用lambda。但是,这不会编译:std::pair>pair(15,[]()->int{return15;});pair.second();因为errorC2664:'std::pair>::pair(conststd::pair>&)':cannotconvertargument2from'main::'to'conststd::packaged_task&'然而,这确实编译:std::ve

c++ - std::复制失败, "cannot seek vector iterator after end"

我整理了这个测试用例,它重现了我在更大的代码中遇到的情况和问题。事实上,我确实需要从POD结构的C数组进行复制,但我希望目标是一个vector,以便它可以自行处理复制删除。TEST_METHOD(std_copy){structW{longa;intb;charc;chard;};Wblock[1]={{15,42,'D','X'}};std::vectordest;dest.reserve(1);std::copy(block,block+1,dest.begin());Assert::AreEqual(42,dest[0].b);}dest.begin()调用中似乎出现了“无法在结

c++ - 如何将 DRY 原则应用于 C++ 中的迭代器? (迭代器、const_iterator、reverse_iterator、const_reverse_iterator)

好的,现在我有两个(完全不相关的,不同的项目)类使用迭代器。一个有iterator和reverse_iterator按预期工作,另一个,当前的有iterator和一个半splinter的const_iterator(具体来说,因为const_iterator派生自iterator,代码LinkedList::iteratori=const_list.begin()是有效的并且允许您修改const定义的列表...)。我打算将所有四种类型添加到此类中......如果可以的话。我将如何继续最小化复制/粘贴代码并仅更改返回类型?创建一个基类,如base_iterator继承自?创建一个iter

c++ - 为什么 basic_string::append (iter, iter) 不调用 std::copy?

我刚刚发现在VisualStudioC++2010中,basic_string::append(iter,iter)显然不是通过使用std::copy.第一个问题:现在假设我实现了自己的迭代器类型,并为我的迭代器类型优化了std::copy重载,以便提供更高效的block式复制。除了重载append之外,还有什么方法可以让basic_string::append使用此优化?basic_string::append(iter,iter)是否有可能不进行字符复制?第二个问题(作为我自己实现的起点):以下是否保证有效?std::stringt("JohnB");std::strings;s.

c++ - 在 Visual Studio 下使用 pair 作为 hash_map 的键

尝试在VisualStudio2010下使用pair作为hash_map的键值。无法编译。int_tmain(intargc,_TCHAR*argv[]){hash_map,int>months;months[pair(2,3)]=1;intd;cin>>d;return0;}收到错误信息:Error1errorC2440:'typecast':cannotconvertfrom'conststd::pair'to'size_t'c:\programfiles\microsoftvisualstudio10.0\vc\include\xhash341testApplication1我知