c如何在结构向量的一个字段上创建迭代器

c如何在结构向量的一个字段上创建迭代器,第1张

概述我有一个所有原始类型的结构,如下所示: struct record { int field1; double field2;} 我有这个结构的实例向量,如下所示: vector<record> records; 是否有可能/什么是创建将迭代field1的向量< int> :: iterator的最佳方法? 如果我使用数组记录记录[n]怎么样?我需要一些看起来像vector< in 我有一个所有原始类型的结构,如下所示:

struct record {    int fIEld1;    double fIEld2;}

我有这个结构的实例向量,如下所示:

vector<record> records;

是否有可能/什么是创建将迭代fIEld1的向量< int> :: iterator的最佳方法?
如果我使用数组记录记录[n]怎么样?我需要一些看起来像vector< int> :: iterator的东西.

编辑:我需要的东西是一个矢量< int> :: iterator.

解决方法 你运气不好

vector< int> :: iterator不是polymorphic1.没有地方可以进入并更改指针步长. vector< int> :: iterator仅迭代一系列连续的int对象,并且不会连续存储int对象.

这就是为什么所有C标准算法都可以接受任何类型的迭代器.如果使函数成为接受任意迭代器类型的模板,则可以像使用Snps编写的那样使用迭代器适配器.

1polymorphism相对于指针算法来说很慢,如果它没有与普通数组相似的性能,没有人会使用std :: vector

总结

以上是内存溢出为你收集整理的c如何在结构向量的一个字段上创建迭代器全部内容,希望文章能够帮你解决c如何在结构向量的一个字段上创建迭代器所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1216394.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存