草庐IT

ostream_iterator

全部标签

c++ - 如何设置 ostream 的指数字段的宽度?

这段代码:#includeintmain(int,char**argv){std::cout打印1.23e+045当使用MSVisualStudio2003编译时,以及1.23e+45在我的Linux机器上。如何指定指数字段的宽度(以及为什么一开始就不同)? 最佳答案 我认为这对于标准操纵器是不可能的。(如果是这样,我很乐意得到纠正并学习如何纠正)您唯一剩下的选择是自己创建一个streambuf,并拦截进入流的所有指数,手动重新格式化它们,然后将它们传递给底层流。看起来工作量很大,虽然不是火箭科学,但也不是微不足道的任务。关于“为什

c++ - 在实现 iterator 和 const_iterator 类时避免代码重复的最佳实践

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭6年前。Improvethisquestion在实现诸如iterator和const_iterator或类似的类对时,避免代码重复的最佳实践是什么?人们是否通常使用大量const_casts根据const_iterator来实现迭代器?是否使用了某种特征类并最终将iterator和const_iterator定义为通用模板的不同实例?这似乎是一个足够普遍的问题,需要一个规范的解决方案,但我没有找到任何专门针对该问题的文章。

c++ - std::ostream 为每一行调用回调

我正在尝试编写一个自定义std::ostream,它为写入的每一行调用一个函数。也就是说,我希望以下代码能够按照注释中的说明工作:my_output_streams([](conststd::string&line){WriteLineToSomeOutput(line);});s请注意,数据不会写入任何地方,也不会存储在任何地方。我唯一需要流存储的是正在聚合的当前行,直到我们遇到行尾。我没有找到任何简单的方法,即使使用boost.Iostreams库也是如此。我可以通过使用STL和Boost的一些内置工具来避免在这里编写自己的行分词器吗?背景my_output_stream类将用于在

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++ - 回复:使用 boost::make_transform_iterator 进行引用访问

我正在尝试使用boost::make_transform_iterator为自定义类创建迭代器,该自定义类的数据保存在映射中,迭代器使用键vector来访问值。在我的问题中,map的值是容纳大量数据的容器。由于我无力复制数据,因此我想通过迭代器通过引用访问数据。但是,这样做时,数据已损坏,如我所附的简单示例的输出所示。据我所知,问题在于使用from_key仿函数(使用映射引用初始化)和boost::make_transform_iterator的语义。关于如何使用boost正确执行此操作的任何想法?谢谢,帕特里克#include#include#include#include#incl

c++ - 'auto' 关键字如何知道何时使用 const_iterator 匹配函数重载?

我了解thisquestion的内容但是当使用函数重载时,事情是如何工作的呢?例如在std::map中定义了以下方法:iteratorfind(constkey_type&k);const_iteratorfind(constkey_type&k)const;如何使用auto关键字来选择一个或另一个?以下内容对我来说似乎不正确:autoi=mymap.find(key);//callsthenon-constmethod?constautoi=mymap.find(key);//callstheconstmethod? 最佳答案 s

c++ - iterator_traits中的嵌套指针类型有什么用?

std::iterator_traits类模板定义了5个嵌套类型:iterator_category,value_type,difference_type,pointer和reference.浏览的来源libc++和libstdc++的头文件,可以看到value_type的许多用途,difference_type和iterator_category,但只有一个reference(在std::iter_swap内)并且pointer没有.我的应用程序使用手工构建的代理迭代器/代理引用对。我想过渡到使用Boostiterator_facade这让我可以从默认的T&配置引用类型到任意类型,但

c++ - 调整自定义迭代器以便(a?)reverse_iterator 可以翻转它的输出

最近,用户@MooingDuck设计了concatenated_range,一个优雅的自定义迭代器,解决了“链接”两个迭代器的问题,一切都在幕后。它非常适合预期用途:autorange0=concatenate_ranges(x,x+i-1,x+i,x+a5+1);a6=foo(range0.first,range0.second);现在,我想通过执行(示例#2)来调整它:autorange0=concatenate_ranges(x+a5+1,x+i-1,x+i+1,x+n);a6=foo(std::reverse_iterator(range0.second),std::rever

c++ - 什么时候应该使用 const_iterator 而不是 auto

下面是一个例子,我认为它说明了使用const_iterator比使用“constauto”更可取的情况。这是因为容器不提供cfind()函数。还有其他选择吗?或者应该使用“constauto”而忽略const的缺失?std::stringGetJobTitle(conststd::string&employee){usingEmployeeTitles=std::unordered_map;EmployeeTitlesemployees={{"Alice","Director"},{"Bob","Manager"},{"Charlie","Developer"}};//Option1.

c++ - 为什么 ofstream::flush() 返回 ostream?

我想做的是:std::ofstreamoutFile(fname,std::ios::binary);//...outFile.flush();outFile.close();效果很好。但是当我尝试合并这两行时,因为flush返回了一个引用:outFile.flush().close();它给出错误提示:error:‘structstd::basic_ostream’hasnomembernamed‘close’然后我更仔细地查看了引用资料,发现它实际上返回ostreaminstreadofofstream..为什么会这样?是错误还是设计? 最佳答案