1

在我之前的问题之后 ,派生类的受保护成员是未知的

我无法理解该行的哪一部分是错误的,知道吗?

这里有一个编译错误:

template <typename K, typename T>
bool graph<K, T>::is_edge(const K& k1, const K& k2)
{
  if (this->nod.find(k1) == this->nod.end() || this->nod.find(k2) == this->nod.end())
    throw std::string("is_edge: Node does not exist");

  if (k1 < k2) // Below line makes error: expected primary-expression!!!!
    return std::find(this->edg.begin(), this->edg.end(), edge(k1, k2)) != this->edg.end();
  return std::find(this->edg.begin(), this->edg.end(), edge(k2, k1)) != this->edg.end();
}

或者,这句话有什么问题:

std::find(this->edg.begin(), this->edg.end(), edge(k1, k2)) != this->edg.end();

完整的代码在这里,您可以在其中测试和编译它。

4

2 回答 2

5

从查看完整的代码,我看到edge也是在基类中定义的。您还必须告诉编译器它是一个从属名称,如下所示:

if (k1 < k2) // Below line makes error: expected primary-expression!!!!
  return std::find(this->edg.begin(), this->edg.end(), typename _base_graph<K, void*, T>::edge(k1, k2)) != this->edg.end();
return std::find(this->edg.begin(), this->edg.end(), typename _base_graph<K, void*, T>::edge(k2, k1)) != this->edg.end();
于 2012-11-16T10:10:05.270 回答
1

您可以像这样通过派生类解析为基类(至少 LLVM 可以 =):

template <typename K, typename T>
bool graph<K, T>::is_edge(const K& k1, const K& k2)
{
    typedef typename graph::edge edge;

    if (this->nod.find(k1) == this->nod.end() || this->nod.find(k2) == this->nod.end())
        throw std::string("is_edge: Node does not exist");

    if (k1 < k2)
        return std::find(this->edg.begin(), this->edg.end(), edge(k1, k2)) != this->edg.end();
    return std::find(this->edg.begin(), this->edg.end(), edge(k2, k1)) != this->edg.end();
}
于 2012-11-16T10:17:25.550 回答