Ответы:
Вы можете попробовать это:
List<Int32> copy = new List<Int32>(original);
или если вы используете C # 3 и .NET 3.5 с Linq, вы можете сделать это:
List<Int32> copy = original.ToList();
MyClass
а Integer
не к ним, копирует ли он элементы или просто ссылается на них?
lstStudentClass
это IEnumerable<StudentClass>
, он будет работать. Если вы испытываете иное, вам нужно предоставить больше информации.
Чтобы добавить содержимое одного списка в другой, который уже существует, вы можете использовать:
targetList.AddRange(sourceList);
Если вы просто хотите создать новую копию списка, посмотрите ответ Лассе.
Для списка элементов
List<string> lstTest = new List<string>();
lstTest.Add("test1");
lstTest.Add("test2");
lstTest.Add("test3");
lstTest.Add("test4");
lstTest.Add("test5");
lstTest.Add("test6");
Если вы хотите скопировать все элементы
List<string> lstNew = new List<string>();
lstNew.AddRange(lstTest);
Если вы хотите скопировать первые 3 элемента
List<string> lstNew = lstTest.GetRange(0, 3);
Этот метод создаст копию вашего списка, но ваш тип должен быть сериализуемым.
Использование:
List<Student> lstStudent = db.Students.Where(s => s.DOB < DateTime.Now).ToList().CopyList();
Метод:
public static List<T> CopyList<T>(this List<T> lst)
{
List<T> lstCopy = new List<T>();
foreach (var item in lst)
{
using (MemoryStream stream = new MemoryStream())
{
BinaryFormatter formatter = new BinaryFormatter();
formatter.Serialize(stream, item);
stream.Position = 0;
lstCopy.Add((T)formatter.Deserialize(stream));
}
}
return lstCopy;
}
ОК, это работает хорошо. Из приведенных выше предложений GetRange () не работает для меня со списком в качестве аргумента ... так что немного подсластите посты выше: (спасибо всем :)
/* Where __strBuf is a string list used as a dumping ground for data */
public List < string > pullStrLst( )
{
List < string > lst;
lst = __strBuf.GetRange( 0, __strBuf.Count );
__strBuf.Clear( );
return( lst );
}