需要:: type的C ++ typedef

时间:2015-10-10 16:47:22

标签: c++ typedef

尝试从BGL开始,这意味着我开始使用很多typedef:

#include <iostream> //std::cin, std::cout
#include <tuple> //std::tie

#include <boost/graph/graph_traits.hpp>
#include <boost/graph/adjacency_list.hpp>

using namespace boost;
typedef adjacency_list<vecS,vecS,undirectedS,no_property,property<edge_weight_t,int> > Graph;
typedef graph_traits<Graph> Traits;
typedef Traits::vertex_descriptor Vertex;
typedef Traits::edge_descriptor Edge;
typedef property_map<Graph, edge_weight_t>::type EdgeWeightMap; //::type necessary (why?)

int main(int argc, char* argv[]){
    int n = ...;
    Graph g(n);
    EdgeWeightMap weight_of;
    Edge e;
    bool success;
    int s,t,w;
    std::cin >> s >> t >> w;
    tie(e,success) = add_edge(s,t,g);
    if(success)weight_of[e] = w;
}

我想知道为什么::type的typedef中的EdgeWeightMap是必要的。如果我省略它,我会

  

错误:'operator []'不匹配(操作数类型为

‘EdgeWeightMap {aka boost::property_map<boost::adjacency_list<boost::vecS, boost::vecS, boost::undirectedS, boost::no_property, boost::property<boost::edge_weight_t, int> >, boost::edge_weight_t>}’
  

‘Edge {aka boost::detail::edge_desc_impl<boost::undirected_tag, unsigned int>}’
  

)      weight_of [e] = w;

(抱歉格式,typedef'<>似乎干扰了blockquote)

事实上,当我尝试

EdgeWeightMap weight_of = get(edge_weight,g);

我得到了

  

错误:从

转换
‘boost::detail::adj_list_any_edge_pmap::bind_<boost::adjacency_list<boost::vecS, boost::vecS, boost::undirectedS, boost::no_property, boost::property<boost::edge_weight_t, int> >, boost::property<boost::edge_weight_t, int>, boost::edge_weight_t>::type {aka boost::adj_list_edge_property_map<boost::undirected_tag, int, int&, unsigned int, boost::property<boost::edge_weight_t, int>, boost::edge_weight_t>}’
  

到非标量类型

‘EdgeWeightMap {aka boost::property_map<boost::adjacency_list<boost::vecS, boost::vecS, boost::undirectedS, boost::no_property, boost::property<boost::edge_weight_t, int> >, boost::edge_weight_t>}’
  

请求     EdgeWeightMap weight_of = get(edge_weight,g);

现在,我可以看到这些是不同的类型,我没有得到的是为什么它们不同。因为我更愿意避免意外,有人可以告诉我何时需要::type以及什么时候不能使用?

1 个答案:

答案 0 :(得分:1)

通过阅读property_map文档,“property_map”模板旨在提供类型,而不是类型。 property_map结构恰好包含两种类型。 typeconst_type,分别用于可变和不可变类型。