如何解决具有递归集合的 C# 克隆类
public class Vorlageneintrag : INotifyPropertyChanged
{
public string erw_Ausgabe { get; set; }
public string erw_Pfad { get; set; }
public string erw_Mailadresse { get; set; }
...
public ObservableCollection<Vorlageneintrag> Items {get; set;}
...
public Vorlageneintrag copy()
{
return (Vorlageneintrag)this.MemberwiseClone();
}
}
工作正常,现在我添加了一个过滤器功能,它删除了所有不匹配“Vorlageneintrag”的过滤器。像我想要的那样工作。但现在我的问题: 如何让我返回原始列表以重置我的过滤器? 通过使用 .toList() 或 .MemberwiseClone() 从副本中重置 Itemssource 仅适用于第一个“层”,但不适用于 Vorlageneintrag.Items 或 Vorlageneintrag.Items[0].Items 和更深的(可以有“无限”子-子子...-树)。还是创建/填充一个全新的对象会更好?
编辑: 过滤:
List<Vorlageneintrag> temp =((ObservableCollection<Vorlageneintrag>)tree_vorlagen.ItemsSource).ToList();
ObservableCollection<Vorlageneintrag> orglist=((ObservableCollection<Vorlageneintrag>)tree_vorlagen.ItemsSource);
foreach (var item in temp)
{
if(Loopandfilter(item).Items.Count==0)
{
orglist.Remove(item);
}
else
{
item.IsNodeExpanded = true;
}
}
private Vorlageneintrag Loopandfilter(Vorlageneintrag item)
{
if(item.Items.Count==0)
{
item.IsNodeExpanded = true;
return item;
}
else
{
List<Vorlageneintrag> temp = item.Items.ToList();
foreach (Vorlageneintrag tmp_item in temp)
{
if (Loopandfilter(tmp_item).Items.Count == 0)
{
if (!tmp_item.erw_Ausgabe.ToLower().Contains(tb_qicksearch.Text.ToLower()))
{
item.Items.Remove(tmp_item);
}
else
{
item.IsNodeExpanded = true;
}
}
}
}
return item;
}
解决方法
当您调用 MemberwiseClone()
时,您正在创建一个浅副本,这意味着不会复制 Items
集合项,而是对集合本身的引用被复制,因此原始和克隆的 Vorlageneintrag
对象将引用相同的 Items
集合。要制作独立于原始对象的深层副本,您可以这样做:
public class Vorlageneintrag : INotifyPropertyChanged
{
public string erw_Ausgabe { get; set; }
public string erw_Pfad { get; set; }
public string erw_Mailadresse { get; set; }
public ObservableCollection<Vorlageneintrag> Items { get; set; }
public Vorlageneintrag Copy()
{
var shallowClone = (Vorlageneintrag)MemberwiseClone();
if (shallowClone.Items == null)
return shallowClone;
var cloneItems = new ObservableCollection<Vorlageneintrag>();
foreach (var item in Items)
cloneItems.Add(item.Copy());
shallowClone.Items = cloneItems;
return shallowClone;
}
public event PropertyChangedEventHandler PropertyChanged;
}
此外,由于您可能绑定到 Items
,您可能应该在 PropertyChanged
setter 中调用 Items
事件,尽管这取决于您的代码的其余部分。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。