6

你好,

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

#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>
        ]

谁能解释为什么这不起作用?我正在使用带有 boost 1.36.0 的 Visual Studio 7.0

谢谢。

4

3 回答 3

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 >);
  }
};
于 2009-01-29T09:58:20.703 回答
6

您必须继承get_valuefromunary_function<const V&, std::pair<K, V> const&>才能知道transform_iterator签名get_value是什么。

于 2009-01-28T21:11:47.917 回答
0
// here is a working example:

#include <vector>
#include <iostream>
#include <boost/iterator/transform_iterator.hpp>

template <typename T, typename U>
const T& Get1st(const std::pair<T, U>& pair) { return pair.first; }

struct Bar {
    using Pairs = std::vector<std::pair<int, char>>;
    using Iter = boost::transform_iterator< decltype(&Get1st<int, char>), Pairs::const_iterator >;

    void add(int i, char c) { _pairs.emplace_back(i, c); }

    Iter begin() { return boost::make_transform_iterator(_pairs.begin(), &Get1st<int, char>); }
    Iter end()   { return boost::make_transform_iterator(_pairs.end(),   &Get1st<int, char>); }

private:
    Pairs _pairs;
};


int main() {
    Bar bar;
    bar.add(1, 'a');
    bar.add(3, 'c');
    bar.add(2, 'b');

    for(const auto& i : bar) std::cout << i << " ";
    std::cout << "\n";

    return 0;
}

// 输出:1、3、2

于 2021-10-13T23:02:50.393 回答