在STL中是否有dereference_iterator? [英] Is there a dereference_iterator in the STL?

查看:98
本文介绍了在STL中是否有dereference_iterator?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想知道如果在STL中有一个迭代器,在返回之前取消引用指向的对象。当操作容器聚合指针时,这可能非常有用。这里是我想要做的一个例子:

I was wondering if there is an iterator in the STL that dereferences the object pointed before returning it. This could be very useful when manipulating containers aggregating pointers. Here's an example of what I would like to be able to do:

#include <vector>
#include <iterator>
#include <algorithm>

using namespace std;

int main()
{
  vector<int*> vec;

  int i = 1;
  int j = 2;
  int k = 3;

  vec.push_back(&i);
  vec.push_back(&j);
  vec.push_back(&k);

  copy(deref_iterator(vec.begin()), 
       deref_iterator(vec.end()), 
       ostream_iterator<int>(cout, " ")); // prints "1 2 3"

  return 0;
}


推荐答案

尝试Boost的 indirect_iterator

Try Boost's indirect_iterator.

indirect_iterator 与包装的迭代器具有相同的类别。例如, indirect_iterator< int **> 是一个随机访问迭代器。

An indirect_iterator has the same category as the iterator it is wrapping. For example, an indirect_iterator<int**> is a random access iterator.

这篇关于在STL中是否有dereference_iterator?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆