如何复制List <t>而不进行克隆</t>

时间:2012-07-28 22:25:32

标签: c# .net copy clone generic-list

也许我错过了一些微不足道的事情。我有几个List<T>,我需要一个大的列表,这是所有其他列表的联合。但我确实希望他们在大名单中提及他们的参考资料,而不仅仅是价值/副本(不像我通常在SO上找到的许多问题)。

例如我有这个,

List<string> list1 = new List<string> { "a", "b", "c" };
List<string> list2 = new List<string> { "1", "2", "3" };

var unionList = GetThatList(list1, list2);

假设我在unionList中获得了我想要的列表,那么这应该发生:

unionList.Remove("a"); => list1.Remove("a");
unionList.Remove("1"); => list2.Remove("1");

//in other words
//
//unionList.Count = 4;
//list1.Count = 2;
//list2.Count = 2;

为清楚起见,这通常发生在

unionList = list1; //got the reference copy.

但是如何使用第二个列表list2添加到unionList

我尝试AddAddRange,但他们显然克隆而不是复制。

unionList = list1;
unionList.AddRange(list2); //-- error, clones, not copies here.

foreach (var item in list2)
{
    unionList.Add(item); //-- error, clones, not copies here.
}

更新:我想我会问一些毫无意义的事情,以及语言本身无法实现的事情......

1 个答案:

答案 0 :(得分:12)

我不认为任何这样的类存在。你可以自己实现它。这是一个开始:

class CombinedLists<T> : IEnumerable<T> // Add more interfaces here.
                                        // Maybe IList<T>, but how should it work?
{
    private List<List<T>> lists = new List<List<T>>();

    public void AddList(List<T> list)
    {
        lists.Add(list);
    }

    public IEnumerator<T> GetEnumerator()
    {
        return lists.SelectMany(x => x).GetEnumerator();
    }

    IEnumerator IEnumerable.GetEnumerator()
    {
        return GetEnumerator();
    }

    public bool Remove(T t)
    {
        foreach (List<T> list in lists)
        {
            if (list.Remove(t)) { return true; }
        }
        return false;
    }

    // Implement the other methods.
}

以下是您可以用来测试它的一些代码:

List<string> list1 = new List<string> { "a", "b", "c" };
List<string> list2 = new List<string> { "1", "2", "3" };
CombinedLists<string> c = new CombinedLists<string>();
c.AddList(list1);
c.AddList(list2);

c.Remove("a");
c.Remove("1");

foreach (var x in c) { Console.WriteLine(x); }
Console.WriteLine(list1.Count);
Console.WriteLine(list2.Count);

删除项目非常简单。但是,如果您尝试将项目插入组合列表,则可能会出现问题。并不总是明确定义哪个列表应该接收插入的项目。例如,如果您有一个包含两个空列表的组合列表,并且您在索引0处插入了一个项目,那么该项目是否应该添加到第一个或第二个空列表中?