質問

HI、

私は問題をコンパイル掲示好きではありませんが、私は本当にこの1を把握することはできません。このコードを使用します:

#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を使用してい1.36.0

感謝します。

役に立ちましたか?

解決

あなたも説明を求めたので、

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 >);
  }
};

他のヒント

あなたはget_valueの署名があるものunary_function<const V&, std::pair<K, V> const&>を伝えるためにtransform_iteratorからget_valueを継承する必要があります。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top