2009-01-28 114 views
4

HI,transform_iterator編譯問題

我不喜歡張貼編譯的問題,但我真的不知道這一個了。使用此代碼:

#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 with boost 1.36.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 >); 
    } 
}; 
+0

的boost ::功能給了我相當多的性能損失,所以我結束了子類化boost :: iterator_adaptor,而不是這樣做,這已經證明是一個更有效率,但第anks。 – Dan 2009-02-18 23:45:25

6

您必須從unary_function<const V&, std::pair<K, V> const&>繼承get_value以告知transform_iteratorget_value的簽名是什麼。