transform_iterator编译问题

时间:2009-01-28 21:05:07

标签: c++ map boost-iterators

HI,

我不喜欢发布编译问题,但我真的无法想出这个问题。使用此代码:

#include <map>
#include <boost/iterator/transform_iterator.hpp>

using namespace std;

template <typename K, typename V>
struct get_value
{
    const V& operator ()(std::pair<K, V> const& p) { return p.second; }
};

class test
{
    typedef map<int, float> TMap;
    TMap mymap;

public:
    typedef get_value<TMap::key_type, TMap::value_type> F;
    typedef boost::transform_iterator<F, TMap::iterator> transform_iterator;

    transform_iterator begin()
    {
        return make_transform_iterator(mymap.begin(), F());
    }
};

获得此编译错误:

transform_iterator.hpp(43) : error C2039: 'result_type' : is not a member of 'get_value<K,V>'
        with
        [
            K=int,
            V=std::pair<const int,float>
        ]

任何人都可以解释为什么这不起作用?我正在使用Visual Studio 7.0和boost 1.36.0

感谢。

2 个答案:

答案 0 :(得分:7)

既然你也要求解释

transform_iterator需要知道所调用函数的返回类型才能实例化自身。这是通过result_of(在<boost/utility/result_of.hpp>

中找到)确定的

如果使用函数对象,则需要定义成员result_type以指定对象的结果类型。 (因为对象没有'返回类型')

如果您使用常规功能,result_of可以自己解决,例如:

template <typename K, typename V>
const V & get_value(std::pair<K, V> const & p)  { return p.second; }

class test
{
  typedef map<int, float> TMap;
  TMap mymap;

public:
  typedef boost::function< const TMap::mapped_type & (const  TMap::value_type &)  > F;
  typedef boost::transform_iterator<F, TMap::iterator> transform_iterator;

  transform_iterator begin()
  {
    return boost::make_transform_iterator(mymap.begin(), &get_value< int, float >);
  }
};

答案 1 :(得分:6)

您必须从get_value继承unary_function<const V&, std::pair<K, V> const&>,告诉transform_iterator get_value的签名是什么。