문제

안녕,

나는 컴파일 문제를 게시하는 것을 좋아하지 않지만 실제로 이것을 알아낼 수는 없습니다. 이 코드 사용 :

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

왜 이것이 작동하지 않는지 설명 할 수 있습니까? 부스트 1.36.0과 함께 Visual Studio 7.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