草庐IT

istream_iterators

全部标签

c++ - Erase-remove 习语 : what happens when remove return past-the-end-iterator?

我在阅读ScottMeyers的erase-removeidiom(第32项)时遇到了这个问题"EffectiveSTL”书。vectorv;...v.erase(remove(v.begin(),v.end(),99),v.end());remove基本上返回“新逻辑结束”和原始范围的元素,这些元素从范围的“新逻辑结束”开始并继续直到范围的真正结束是要删除的元素从容器中删除。听起来不错。现在,让我问我的问题:在上面的例子中,如果vectorv中没有找到99,remove可以返回v.end()。它基本上是将past-the-end-iterator传递给erase方法。当past-th

c++ - STL 算法如何独立于 Iterator 类型工作?

STL算法如何独立于迭代器类型工作? 最佳答案 真的,他们只是工作。它们使用模板的一些非常基本的属性,有时称为静态多态性。如果您熟悉该术语,它本质上是一种鸭式输入形式。(如果它长得像鸭子,而且叫起来像鸭子,那一定是鸭子)技巧很简单。这是一个非常简单的例子:templatevoidsay_hello(constT&t){t.hello();}say_hello函数不关心它的参数是哪种类型。它不必从接口(interface)派生或做出任何其他类型的关于它是什么的“promise”。重要的是类型在这种情况下有效。我们对该类型所做的一切就是

c++ - 尝试从 istream 存储 token 时出现段错误

我的代码在读取文件时崩溃(见本文末尾)。我在main中声明一个ifstream对象,将其传递给buildGraph函数(将ifstream&作为参数),并尝试将第一个标记传递到字符串temp中。main的相关代码:#includeintmain(){ifstreaminfile1("data31.txt");if(!infile1){cout来自graphm.cpp的相关代码:#include#includevoidGraphM::buildGraph(ifstream&input){stringtemp;input>>temp;}还有一个头文件graphm.h也包含fstream。我

C++标准写法: Does "through all iterators in the range" imply sequentiality?

ThisSOquestion引发了关于std::generate和标准做出的保证的讨论。特别是,你能否使用具有内部状态的函数对象并依赖于generate(it1,it2,gen)来调用gen(),将结果存储在*it,再调用gen(),存入*(it+1)等,还是可以从后面开始,比如?标准(n3337,§25.3.7/1)是这样说的:Effects:Thefirstalgorithminvokesthefunctionobjectgenandassignsthereturnvalueofgenthroughalltheiteratorsintherange[first,last).Thes

c++ - 失败时 C++ 中的 istream 行为更改

取自:cppreference直到C++11:Ifextractionfails(e.g.ifaletterwasenteredwhereadigitisexpected),valueisleftunmodifiedandfailbitisset.从C++11开始:Ifextractionfails,zeroiswrittentovalueandfailbitisset.Ifextractionresultsinthevaluetoolargeortoosmalltofitinvalue,std::numeric_limits::max()orstd::numeric_limits::

c++ - istream 的 tellg/seekg 无法防止堆栈粉碎(g++)?

对于我正在编写的程序,计算文件大小对我来说很有用,我使用iostream的tellg和seekg函数计算文件大小,但这会导致-Wstack-protector发出警告。以下代码重现了“问题”:#includestd::streamsizeget_file_size(std::ifstream&ifs){//line12(inwarning,below)conststd::streamsizestart=ifs.tellg();ifs.seekg(0,std::ios::end);conststd::streamsizeend=ifs.tellg();ifs.seekg(start);r

java - 在 JNI 中连接 C++ istream/ostream 和 Java InputStream/OutputStream

是否有任何现有的C++/JNI库可以在JavaInputStream和C++istream以及JavaOutputStream之间编码访问和C++ostream?特别是,我希望Java应用程序能够将InputStream或OutputStream传递到使用iostreams作为其流接口(interface)的C++库中.如果不存在现有库,我需要在istream/ostream实现中实现的最低功能是什么以支持它?更糟糕的是,我还需要支持seek和tell,尽管原则上我应该能够使用mark、重置,然后跳过以执行我需要的操作。由于这些流可能非常大,我不想简单地将它们加载到ByteArray中

c++ - 可以从 istream_iterator 制作 move_iterator 吗?

考虑以下代码:typedefistream_iteratorchar_itr;char_itreos;stringll("sometexthere");istringstreamline_in(ll);char_itrstart(line_in);move_iteratormstart(start);//!!!move_iteratormeos(eos);vectorvc(mstart,meos);上面的代码由于行(!!!)而无法编译:errorC2440:'return':cannotconvertfrom'constchar'to'char&&'但是,如果您分别用start和eos

c++ - 我如何定义 map::iterator 列表和 list::iterator 映射

我需要一个Map::iterator列表和List::iterator映射。我该怎么做:typedefstd::listList;typedefstd::mapMap;也许我可以使用迭代器的前向声明之类的东西? 最佳答案 像这样的东西应该可以帮助你:#include#include#include#include#includestructdecl_t{typedefstd::mapmap_t;typedefstd::list>list_t;list_t::iteratorit;};intmain(intargc,constchar

c++ - istream 没有完全恢复已放入 stringstream 的内容

我使用以下设置:#includeusingnamespacestd;classfoo{public:voidbar(istream&in,intn){vector>q;intx,y,a,b;for(q.clear();in>>x>>y>>a>>b;q.push_back(make_tuple(x,y,a,b)));assert(n==q.size());}};intmain(){stringstreamss;for(inti=0;ibar(ss,100);}事实上,我的代码比这更复杂,但我的想法是将东西(准确地说是longlongint)放入stringstream并调用一个函数,将创