transform_iterator编译问题
-
20-08-2019 - |
题
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升压1.36.0
感谢。
解决方案
既然你还要求一个解释
在transform_iterator
需要知道被叫为了实例化本身的函数的返回类型。这是通过 result_of
确定(在发现<boost/utility/result_of.hpp>
如果您使用的功能对象,需要定义一个构件result_type
来指定对象的结果类型。 (因为对象不具有“返回类型”本身)
如果你会使用常规的功能,result_of
将能够弄明白他自己,e.g:
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
的签名是什么。
不隶属于 StackOverflow