problème de compilation de transform_iterator
-
20-08-2019 - |
Question
HI,
Je n'aime pas écrire des problèmes de compilation, mais je ne peux vraiment pas comprendre celui-ci. En utilisant ce code:
#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());
}
};
Obtention de cette erreur de compilation:
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>
]
Quelqu'un peut-il expliquer pourquoi cela ne fonctionne pas? J'utilise Visual Studio 7.0 avec boost 1.36.0
Merci.
La solution
Puisque vous avez également demandé une explication
Le transform_iterator
besoin de connaître le type de retour de la fonction appelée pour s'instancier lui-même. Ceci est déterminé via result_of
( trouvé dans <boost/utility/result_of.hpp>
Si vous utilisez un objet fonction, vous devez définir un membre result_type
pour spécifier le type de résultat de l'objet. (puisqu'un objet n'a pas de "type de retour" en tant que tel)
Si vous aviez utilisé une fonction régulière, <=> serait capable de la découvrir par elle-même, par exemple:
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 >);
}
};
Autres conseils
Vous devrez hériter get_value
de unary_function<const V&, std::pair<K, V> const&>
pour indiquer à transform_iterator
quelle est la signature de <=>.