序列化:將對象的狀態信息及類型信息,轉換爲一種易於傳輸或存儲形式(流,即字節序列)的過程。編程
下圖爲序列化過程圖示,圖片來自微軟官方文檔:api
反序列化:與序列化相反,將流轉換爲對象的過程。框架
經常使用的有二進制序列化、XML序列化及JSON序列化三種序列化方式。.NET自身提供了對二進制序列化與XML序列化的支持。咱們能夠藉助第三方庫,如Newtonsoft.Json,來實現JSON序列化。編程語言
二進制序列化會將對象的全部屬性(即便訪問修飾符是private)轉換到流中,XML/JSON則只轉換訪問修飾符爲public的屬性。在反序列化時,二進制形式不會調用構造函數,能夠藉助二進制序列化來實現深拷貝。ide
XML/JSON序列化不受編程語言限制,C#使用XML/JSON序列化後的數據JAVA能夠很容易的按照XML或JSON的格式反序列化獲得所需數據。相對而言,二進制序列化則受到編程語言的限制。函數
除了上述三種序列化方式外,有些公司推出了本身的序列化框架,如:谷歌的protobuf 。ui
[Serializable] public class Person { public Person() { Console.WriteLine("ctor"); } public Person(int gender) { _gender = gender; Console.WriteLine("ctor with parameter"); } private static int TAG = 20; private int _gender; public string Name { set; get; } public int Age { set; get; } } // 建立對象 var p = new Person(10) { Name = "xfh", Age = 26 };
二進制序列化:google
// 二進制序列化,序列化全部屬性及字段(即使是訪問級別是private) var binaryFormatter = new BinaryFormatter(); using (var stream = new MemoryStream()) { binaryFormatter.Serialize(stream, p); Console.WriteLine(stream.Length); stream.Position = 0; // 反序列化不會調用構造函數 var newP = (Person)binaryFormatter.Deserialize(stream); }
XML序列化:spa
// xml序列化,目標類型必須具備無參構造函數,只會序列化public屬性 var xmlFormatter = new XmlSerializer(typeof(Person)); using (var stream = new MemoryStream()) using (var fs = new FileStream(@"C:\Users\xfh\Desktop\stream.xml", FileMode.OpenOrCreate)) using (var sr = new StreamReader(stream)) using (var sw = new StreamWriter(fs)) { // 序列化 xmlFormatter.Serialize(stream, p); stream.Position = 0; // 寫入XML文件中 while (sr.EndOfStream == false) { var content = sr.ReadLine(); sw.WriteLine(content); } stream.Position = 0; // 反序列化 var newP3 = (Person)xmlFormatter.Deserialize(stream); }
JSON序列化,藉助Newtonsoft.Json來實現:3d
// Json序列化,只會序列化public屬性 var pStr = JsonConvert.SerializeObject(p); Console.WriteLine(System.Text.Encoding.Default.GetByteCount(pStr)); var newP2 = JsonConvert.DeserializeObject<Person>(pStr);
下面三張圖片均來自公衆號:碼農翻身中的文章——序列化: 一個老傢伙的鹹魚翻身,推薦你們閱讀(碼農翻身中有許多優秀的文章值得閱讀)。
二進制序列化:
XML/JSON序列化:
二進制序列化跨語言解決方案: