我有一个课程如下:
class Graph
{
private :
vector<Graph*> children;
Board* tab;
[...]
public :
vector<Graph*> getchildren();
Board* gettab();
[...]
}
Board* Graph::gettab() { return this->tab; }
vector<Graph*> Graph::getchildren() { return this->children; }
我需要做一个遍历子项内每个选项卡的循环(为了打印它们,测试addChildren方法是否有效)。
我开始这样做:
for(vector<Graph*>::iterator itr = tree.getchildren().begin(); itr != tree.getchildren().end(); ++itr){
//huh... Help ?
}
我的问题是,现在,我如何访问向量中的选项卡?我有和迭代器&#34;选择&#34; getchildren返回的向量中的每个图,但迭代器没有这些方法。一行像itr.gettab();显然会赢得工作,而tree.getchildren()。itr.Graph :: gettab();告诉我,树没有itr成员。
我该怎么办?在Graph?
中创建一个itr成员答案 0 :(得分:1)
使用vector<Graph*>::iterator itr = tree.getchildren().begin()
*itr
是Graph*
因此,您可以致电(*itr)->gettab()
。
此外,您需要在for循环之前将向量存储在局部变量中。
std::vector<Graph*> children = tree.getchildren();
for(std::vector<Graph*>::iterator itr = children.begin();
itr != children.end();
++itr)
{
Graph* graph = *itr;
graph->gettab();
(*itr)->gettab();
}
C ++ 11中一种更简单的方法,既不需要迭代器也不需要本地向量:
for (Graph* graph : tree.getchildren()) {
graph->gettab();
}
注意:正如评论
中所述vector<Graph*> getchildren();
应该是
vector<Graph*>& getchildren();
如果您这样做,则不再需要本地变量。