Maison >
Article > développement back-end > Présentez brièvement le problème de copie complète de l'objet List
L'éditeur suivant vous proposera une brève discussion sur le problème de copie profonde de List8742468051c85b06f0a0af9e3e506b5cobjet en C#. L'éditeur pense que c'est plutôt bien, alors je vais le partager avec vous maintenant et le donner comme référence. Suivons l'éditeur et jetons un coup d'œil ensemble
1. Lorsque T dans l'objet List8742468051c85b06f0a0af9e3e506b5c est un type valeur (type int, etc.)
Pour la Liste des types de valeurs, vous pouvez la copier directement en utilisant la méthode suivante :
List<T> oldList = new List<T>(); oldList.Add(..); List<T> newList = new List<T>(oldList);
2. Lorsque T dans l'objet Liste8742468051c85b06f0a0af9e3e506b5c type (comme une classe Entity personnalisée)
1. La liste de type référence ne peut pas être copiée en utilisant la méthode ci-dessus. Seules les références des objets de la liste seront copiées. utilisez la méthode d'extension suivante pour copier :
static class Extensions { public static IList<T> Clone<T>(this IList<T> listToClone) where T: ICloneable { return listToClone.Select(item => (T)item.Clone()).ToList(); } //当然前题是List中的对象要实现ICloneable接口 }
2. Une autre méthode de sérialisation est utilisée pour effectuer une copie approfondie de l'objet de référence. Cette méthode est la plus fiable
public static T Clone<T>(T RealObject) { using (Stream objectStream = new MemoryStream()) { //利用 System.Runtime.Serialization序列化与反序列化完成引用对象的复制 IFormatter formatter = new BinaryFormatter(); formatter.Serialize(objectStream, RealObject); objectStream.Seek(0, SeekOrigin.Begin); return (T)formatter.Deserialize(objectStream); } }
. 3. Utilisez System.Xml.Serialization pour implémenter la sérialisation et la désérialisation
public static T Clone<T>(T RealObject) { using(Stream stream=new MemoryStream()) { XmlSerializer serializer = new XmlSerializer(typeof(T)); serializer.Serialize(stream, RealObject); stream.Seek(0, SeekOrigin.Begin); return (T)serializer.Deserialize(stream); } }
3. Testez la copie complète des objets ci-dessus
Le test est le suivant :
using System; using System.Collections.Generic; using System.Collections ; using System.Linq; using System.Text; using System.IO; using System.Runtime.Serialization; using System.Runtime.Serialization.Formatters.Binary; namespace LINQ { [Serializable] public class tt { private string name = ""; public string Name { get { return name; } set { name = value; } } private string sex = ""; public string Sex { get { return sex; } set { sex = value; } } } class LINQTest { public static T Clone<T>(T RealObject) { using (Stream objectStream = new MemoryStream()) { IFormatter formatter = new BinaryFormatter(); formatter.Serialize(objectStream, RealObject); objectStream.Seek(0, SeekOrigin.Begin); return (T)formatter.Deserialize(objectStream); } } public static void Main() { List<tt> lsttt = new List<tt>(); tt tt1 = new tt(); tt1.Name = "a1"; tt1.Sex = "20"; lsttt.Add(tt1); List<tt> l333 = new List<tt>(); l333.Add(Clone<tt>(lsttt[0])); l333[0].Name = "333333333"; } } }
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!