草庐IT

non-iterator

全部标签

c++ - 没有从 const_iterator 类型的返回值到迭代器的可行转换

灵感来自Antony'sWilliams"C++ConcurrencyinAction"我想仔细看看他的线程安全HashMap。我复制了它的代码并添加了一些输出运算符,这就是我想出的:#include#include#include#include#includetemplate>classthread_safe_hashmap{private:classbucket_type{public:typedefstd::pairbucket_value;typedefstd::listbucket_data;typedeftypenamebucket_data::iteratorbucke

C++: 奇怪的 "Request for member X of Y which is of non-class type Z"

以下程序,用g++4.6编译,产生错误requestformember‘y’in‘a2’,whichisofnon-classtype‘A(B)’最后一行:#includetemplateclassA{public:Ty;A(Tx):y(x){}};classB{public:intu;B(intv):u(v){}};intmain(){intv=10;Bb1(v);//worksAa1(b1);//doesnotwork(theerroriswhena2isused)Aa2(B(v));//works//Aa2((B(v)));std::cout从代码中包含的工作变体可以看出,在A的

c++ - iterator 和 back_insert_iterator 有什么区别?

如果随机访问迭代器可用于访问相对于它们指向的元素的任意偏移位置的元素(有点像指针),为什么它们不能用于像std::copy()这样的通用算法而不是使用back_insert_iterator,两者有什么区别? 最佳答案 std::back_insert_iterator是一种特定类型的output迭代器,它支持push_back操作。当您使用operator=write时,它会将值push_back到底层容器中—因此,从这个意义上说,它充当具有push_back的容器的适配器成员函数。举个例子很容易理解:std::vectorv;s

C++ -- STL Vector::const_iterator 为什么不使用 < xx.end()?

//displayvectorelementsusingconst_iteratorfor(constIterator=integers.begin();constIterator!=integers.end();++constIterator)cout我们可以使用constIterator吗??谢谢 最佳答案 operator仅为randomaccessiterators定义。例如,这些由std::vector提供。和std::string,本质上是将数据存储在连续存储中的容器,其中迭代器通常只不过是包装指针。提供的迭代器,例如s

c++ - cppcheck 错误 : Dangerous iterator usage

代码:for(x=abc.begin();x!=abc.end();x++){if(-----){----abc.erase(x);}}错误是:::危险的迭代器用法删除后迭代器无效,因此取消引用它或将它与另一个迭代器进行比较是无效的。上面代码中使用erase函数的错误用法是什么? 最佳答案 删除abc对应的值后,itaratorx无效。这应该修复它:x=abc.begin();while(x!=abc.end()){if(-----){----x=abc.erase(x);//skippedonlytonextitem}else{/

c++ - 何时以及为何会生成 std​​::__non_rtti_object 异常?

我正在使用VisualStudio并执行有效的动态转换。启用RTTI。编辑:更新代码使其更真实structbase{virtualbase*Clone(){base*ptr=newbase;CopyValuesTo(ptr);returnptr;}virtualvoidCopyValuesTo(base*ptr){...}virtual~base(){}}structderived:publicbase{virtualbase*Clone(){derived*ptr=newderived;CopyValuesTo(ptr);returnptr;}virtualvoidCopyValue

c++ - find_if 不适用于 const_iterator

我写了这个程序://splitsasentenceintowords#include#include#include#include"spacefunc.h"usingstd::string;usingstd::cout;usingstd::endl;usingstd::find_if;intmain(){typedefstring::const_iteratoriter;stringinput="Thisisme";iteri=input.begin();while(i!=input.end()){iterj;i=find_if(i,input.end(),notspace);j=f

c++ - 'iter' 的名称查找更改为新的 ISO 'for' 范围

我正在尝试编译下面的两个文件,但从编译器那里得到一条错误消息:gcc4.3.3(Linux)错误在签名行:LINEWITHERROR我做错了什么,我应该怎么改?路易斯.....................................$g++-cb.hb.cppb.cpp:Infunction'voidcalcularDesempPop(std::vector>&)':b.cpp:19:error:namelookupof'iter'changedfornewISO'for'scopingb.cpp:17:error:usingobsoletebindingat'iter'...

c++ - STL 算法和 const_iterators

今天我写了一个小谓词来查找容器中的匹配符号。但是我遇到了一个问题:我想在类的常量方法内的std::find_if调用中使用这个谓词,在属于这个类。但我刚刚注意到std::find和std::find_if都不能对const_iterators进行操作!我检查了一些C++引用资料,似乎没有std::find或std::find_if版本接受/返回const_iterators。我只是不明白为什么,因为据我所见,这些算法无法修改迭代器引用的对象。这是在SGI实现中记录std::find的方式:Returnsthefirstiteratoriintherange[first,last)suc

c++ - 哪个更好 : a lying copy constructor or a non-standard one?

我有一个包含不可复制句柄的C++类。但是,该类必须有一个复制构造函数。因此,我实现了一个将句柄的所有权转移到新对象的方法(如下所示),classFoo{public:Foo():h_(INVALID_HANDLE_VALUE){};//transferthehandletothenewinstanceFoo(constFoo&other):h_(other.Detach()){};~Foo(){if(INVALID_HANDLE_VALUE!=h_)CloseHandle(h_);};//otherinterestingfunctions...private:///disallowas