草庐IT

istream-iterator

全部标签

c++ protobuf : how to iterate through fields of message?

我是protobuf的新手,但我的任务很简单:我需要遍历消息字段并检查它的类型。如果类型是消息,我将递归地对此消息执行相同的操作。例如,我有这样的消息:packageMyTool;messageConfiguration{requiredGloablSettingsglobalSettings=1;optionalstringoption1=2;optionalint32option2=3;optionalbooloption3=4;}messageGloablSettings{requiredbooloption1=1;requiredbooloption2=2;requiredbo

c++ - gtk_widget_add_tick_callback() 和 gtk_main_iteration()

我有两个GTK窗口运行动画的普通(主)窗口,在gtk_widget_add_tick_callback()注册的回调中绘制内容。在某个时候会创建运行模态循环的辅助窗口:voidshow_modal(){GtkWindow*gw=gtkwindow(this);if(parent())gtk_window_set_transient_for(gw,gtkwindow(parent()));gtk_widget_show(GTK_WIDGET(gw));gtk_window_set_modal(gw,TRUE);gtk_window_set_keep_above(gw,TRUE);this

c++ - std::map<K,V>::iterator 是否实例化 std::map<K,V>?

我有这段代码,它适用于GCC:#includeclassFoo;classBar;typedefstd::mapMyMap;MyMap::iteratori;classFoo{MyMap::iteratorsome_data;};当前设计的代码(这是令人不快的循环,是的,我坚持使用它)需要map::iterator可用于Foo和Bar.之所以有效,是因为GCC库实现恰好不需要实例化映射的键类型来实例化迭代器。这是有保证的吗?在定义映射迭代器类型时,该标准似乎有些放任自流。这段代码的可移植性如何? 最佳答案 这会导致未定义的行为。在声

c++ - 'iterator' 可以只输入子类 'const_iterator' 吗?

在anotherquestionaboutiterators之后我对自定义容器有一些疑问。在我的容器中,iterator是const_iterator的子类,因此我可以“免费”从非const转换为const。但这是否允许,或者这样的设置是否有任何缺点或不工作的情况? 最佳答案 是的,这很好。这就是VC10对vector的迭代器的实现方式。例如,是结构化的。见_Vector_iterator和_Vector_const_iterator在.顺便说一句,编写迭代器很困难。值得您花时间学习和使用boost::iterator库。

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

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

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

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

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++ - 有没有办法检查 istream 是否以二进制模式打开?

我正在使用一个istream,它可以是stringstream、ifstream或用户定义的流类型,我需要知道如果是ifstream,它是否没有以二进制模式打开(所以我可以抛出异常)。我试过以下方法:if((_is.flags()&ios::binary)==0)throwexception(...)但是从来没有抛出异常。在这种情况下测试失败,因为_is.flags()返回0x201而ios::binary是0x20。有没有办法确定流是否以文本模式打开? 最佳答案 flags()返回ios_base::fmtflags这是格式化标志