我有一个以层次结构显示的父项和子项列表。我想切换它们的 expanded
属性。因此,如果单击父项并且显示父项的子项,那么所有父项的子项都将折叠,反之亦然
Stackoverflow 跟踪指向这一行
if (childItem.getItemId() == item.getItemId()) {
hideItemAndDescendants(childItem); //causing stack overflow
}
我知道当一个方法不断地 self 调用时会发生计算器溢出。但在这种情况下,我有一个 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。
关于java.lang.StackOverflowError。为什么我在这里收到 Stackoverflow 异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18250546/