我有一个父级和子级的项目列表,以层次结构显示。我想切换他们的expanded
属性。因此,如果单击父级,并且父级的孩子正在显示,则所有父级孩子都将折叠,反之亦然
Stackoverflow跟踪点指向此行
if (childItem.getItemId() == item.getItemId()) {
hideItemAndDescendants(childItem); //causing stack overflow
}
我认为当方法不断自我调用时会发生stackoverflow,但是在这种情况下,我有一个For循环,该循环仅遍历
items
列表,并且列表大小仅为10左右。public boolean toggleNodeCollapseState(long itemId) {
boolean changed = false; // a flag to determine if anything collapsed or expanded
for (int i = 0; i < items.size(); i++) {
Item childItem = items.get(i);
if (childItem.getParentItemId() == itemId) {
changed = true;
childItem.setCollapsed(!childItem.isCollapsed());
if (childItem.isCollapsed()) {
hideItemAndDescendants(childItem);
} else {
showDescendants(childItem);
}
}
}
return changed;
}
public void hideItemAndDescendants(Item item) {
item.hide();
for (int i = 0; i < items.size(); i++) {
Item childItem = items.get(i);
if (childItem.getItemId() == item.getItemId()) {
hideItemAndDescendants(childItem);
}
}
}
public void showDescendants(Item item) {
item.hide();
for (int i = 0; i < items.size(); i++) {
Item childItem = items.get(i);
if (childItem.getItemId() == item.getItemId()) {
childItem.show();
if (!childItem.isCollapsed()) {
showDescendants(childItem);
}
}
}
}
最佳答案
您在hideItemAndDecendants中有一个递归调用:
for (int i = 0; i < items.size(); i++) {
Item childItem = items.get(i);
if (childItem.getItemId() == item.getItemId()) {
hideItemAndDescendants(childItem);
}
}
因此,如果使用
childItem.getItemId() == item.getItemId()
,您将再次调用hideItemAndDescendants(childItem);
。这可能会导致无限循环,从而导致您的stackoverflowexception。