草庐IT

ostream_iterator

全部标签

c++ - 从 istream 到 ostream 的快速受控复制

我必须将几个字节从istream复制到ostream,我知道执行此复制的方法有两种。myostream和copy(istreambuf_iterator(myistream),istreambuf_iterator(),ostreambuf_iterator(myostream));我发现rdbuf版本的速度至少是copy的两倍。我还没有找到复制的方式,比如100个字节,但是由于要复制的大小可能会很大,如果可能的话,我希望能够使用rdbuf版本。如何将这些拷贝限制为给定的字节数? 最佳答案 你可以使用0x吗?如果是这样,那么您可以使

c++ - 嵌套在类模板中的类 X 的 operator<<(ostream&, X)

这个编译和工作正常(非嵌套模板):#includetemplateclassZ;templatestd::ostream&operator&){return(osclassZ{friendstd::ostream&operator(std::ostream&os,constZ&);};intmain(){Zz;std::cout这个不能编译(gcc4.4和gcc4.6,在03和0x模式下):#includetemplateclassZ;templatestd::ostream&operator::ZZ&){return(osclassZ{public:classZZ{friendstd

c++ - 为什么 vector::iterator 在重新分配时无效?

我不明白为什么在重新分配发生时vector的迭代器应该失效。难道不能简单地通过在迭代器中存储一个偏移量——而不是一个指针——来防止这种情况吗?为什么vector不是这样设计的? 最佳答案 只是为与性能相关的理由添加一个引用:在设计C++时,Stroustrup认为模板类如std::vector是至关重要的。接近原生数组的性能特点:Onereasonfortheemphasisonrun-timeefficiency...wasthatIwantedtemplatestobeefficientenoughintimeandspacet

c++ - 为什么 ostream 为定义为 `1` 的字符串打印 `volatile char[]` ?

这个问题在这里已经有了答案:Whydoesstd::coutconvertvolatilepointerstobool?(4个回答)关闭8年前。考虑这个(人工)示例:#include#includeintmain(){volatilechartest[]="abc";std::printf("%s\n",test);std::cout使用GCC编译并运行会得到以下输出:$g++test.cc$./a.outabc1如您所见,printf正确打印字符串,而cout打印1。为什么在这种情况下写入cout会产生1? 最佳答案 operat

c++ - 将 std::list<>::iterator 的值指向指针?

如何循环通过STL::List并存储其中一个对象的值以供稍后在函数中使用?Particle*closestParticle;for(list::iteratorp1=mParticles.begin();p1!=mParticles.end();++p1){//ExtrastuffremovedclosestParticle=p1;//failstocompile(editfromcomments)} 最佳答案 要么Particle*closestParticle;for(list::iteratorit=mParticles.be

c++ - 我应该如何在 API 中替换 vector<uint8_t>::const_iterator?

我的任务是完善编解码器库的界面。我们使用的是C++17,我只能使用标准库(即没有Boost)。目前,有一个Decoder大致如下所示的类:classDecoder:publicCodec{public:structResult{vector::const_iteratornew_buffer_begin;optionalmetadata;optionalpacket;};Resultdecode(vector::const_iteratorbuffer_begin,vector::const_iteratorbuffer_end);private://irrelevantdetails

C++ 迭代器到 const_iterator

如何在C++中从iterator(该容器类的)获取一个const_iterator(某个容器类的)?insert_iterator中的const_iterator怎么样?生成的iterator应该指向与原始位置相同的位置。 最佳答案 容器需要提供iterator作为可转换为const_iterator的类型,因此您可以隐式转换:Container::iteratorit=/*blah*/;Container::const_iteratorcit=it;std::insert_iterators是输出迭代器。这无法将它们转换为必须是前

c++ - iterator_trait 的典型用例是什么

我是C++新手,所以请多多包涵。我想了解STLiterator_traits.在“C++标准库”一书中,结构iterator_traits定义如下:templatestructiterator_traits{typedeftypenameT::value_typevalue_type;typedeftypenameT::difference_typedifference_type;typedeftypenameT::iterator_categoryiterator_category;typedeftypenameT::pointerpointer;typedeftypenameT::

C++ 双端队列 : when iterators are invalidated

如果我错了,请纠正我。谢谢!insert和erase将重定位元素,但插入/删除发生位置之前的元素不会重定位,因此它们的迭代器仍然有效。push_back和pop_back不会使任何迭代器失效。push_front和pop_front使所有迭代器无效。swap不会重新定位元素,但不知何故我认为它应该使迭代器无效。 最佳答案 push_back()和push_front()是根据insert()定义的。类似地,pop_back()和pop_front()是根据erase()定义的。以下是C++03标准关于insert()(23.2.1.

c++ - 为什么 ostream::write() 在 C++ 中需要 ‘const char_type*’ 而不是 ‘const void*’?

fwrite()C中的函数使用constvoid*restrictbuffer作为第一个参数,因此您可以将指针传递给您的struct直接作为第一个参数。http://en.cppreference.com/w/c/io/fwrite例如fwrite(&someStruct,sizeof(someStruct),1,file);但在C++中,ostream::write()需要constchar_type*,这会迫使您使用reinterpret_cast.(在VisualStudio2013中,它是constchar*。)http://en.cppreference.com/w/cpp/