所谓的序列化就是是将对象转换为容易传输的格式的过程,一般情况下转化打流文件,放入内存或者IO文件中。例如,可以序列化一个对象,然后使用 HTTP 通过 Internet 在客户端和服务器之间传输该对象,或者和其它应用程序共享使用。反之,反序列化根据流重新构造对象。
  
  .NET自带的有两种序列化对象的方式,Xml和binary的,XML 序列化不转换方法、索引器、私有字段或只读属性(只读集合除外)。要序列化对象的所有字段和属性(公共的和私有的),请使用 BinaryFormatter,而不要使用 XML 序列化(参见ms-help://MS.NETFramework.v20.chs/dv_fxserialization/html/8c63200d-db63-4a03-a93d-21641623df62.htmXML 和 SOAP 序列化)。

两者的程序处理方式基本一致,都是基于工厂模式的,下面我就只说二进制的序列化的方式:
   例如我们有个对象: [Serializable]public class ClassToSerialize{
    public int id=100;
    public string name="Name";
}
  
需要序列化该对象,必须在给该类加上Serializable的属性,然后创建一个序列化写入的流:FileStream fileStream = new FileStream("temp.dat", FileMode.Create);然后创建二进制格式器:BinaryFormatter b=new BinaryFormatter();然后是序列化:b.Serialize(fileStream,c);,然后关闭保存流。(可以见下面的例子)
 
   读取一个已经被序列化的对象的时候:操作方式一样,只是FileStream fileStream = new FileStream("temp.dat", FileMode.Open, FileAccess.Read, FileShare.Read);
ClassToSerialize c =(ClassToSerialize)b.Deserialize(fileStream);
然后就可以读取了,完整的例子是:

using System;
using System.IO;
using System.Runtime.Serialization;
using System.Runtime.Serialization.Formatters.Binary;
public class SerialTest{
    public void SerializeNow(){
        ClassToSerialize c=new ClassToSerialize();
        FileStream fileStream = new FileStream("temp.dat", FileMode.Create);

BinaryFormatter b=new BinaryFormatter();
        b.Serialize(fileStream,c);
        fileStream.Close();
    }
    public void DeSerializeNow(){
        ClassToSerialize c=new ClassToSerialize();
        FileStream fileStream = new FileStream("temp.dat", FileMode.Open, FileAccess.Read, FileShare.Read);
        BinaryFormatter b=new BinaryFormatter();//SoapFormatter
        c=(ClassToSerialize)b.Deserialize(fileStream);
        Console.WriteLine(c.name);
        fileStream.Close();
    }
    public static void Main(string[] s){
        SerialTest st=new SerialTest();
        st.SerializeNow();
        st.DeSerializeNow();
    }
}
[Serializable]
public class ClassToSerialize{
    public int id=100;
    public string name="Name";
}

这就是自带的序列化和反序列的操作,但是,很多情况下,一个对象比较大,而且很多私有的属性和方法我们不需要,例如在原型模式里面序列化的话,只需要序列Clone方法和一些属性,私有的方法无需要,还例如在读取大规模的IO的时候,读取操作完全不需要... 这时候就需要自己集成重写序列的ISerializable接口:

实现该接口需要两个注意的,一个就是构造函数,主要是为了反序列,另一个就是GetObjectData,主要是执行序列化,例如我们现在有一个Employee类需要序列化    [Serializable()]    //Set this attribute to all the classes that want to serialize
    public class Employee : ISerializable //derive your class from ISerializable {
        public int EmpId;
        public string EmpName;
        [NonSerialized()]
    public string NoSerialString="NoSerialString-Test";

}
,需要注意的是我这里的NoSerialString属性前面有[NonSerialized()],就是说默认并不序列化这个属性,而是使用默认值 。

首先是构造函数:        public Employee(SerializationInfo info, StreamingContext ctxt)
        {
            EmpId = (int)info.GetValue("EmployeeId", typeof(int));
            EmpName = (String)info.GetValue("EmployeeName", typeof(string));
            //NoSerialString = (String)info.GetValue("NoSerialString", typeof(string));
        }

然后是序列化方法,就是当写入流的时候怎么保存的:
        public void GetObjectData(SerializationInfo info, StreamingContext ctxt)
        {
            //You can use any custom name for your name-value pair. But make sure you
            // read the values with the same name. For ex:- If you write EmpId as "EmployeeId"
            // then you should read the same with "EmployeeId"
            info.AddValue("EmployeeId", EmpId);
            info.AddValue("EmployeeName", EmpName);
        }

把上面两个方法写入到Employee类,然后写个测试的程序:
public class ObjSerial{
    public static void Main(String[] args){
        Employee mp = new Employee();
        mp.EmpId = 10;
        mp.EmpName = "Omkumar";
        mp.NoSerialString = "你好啊";
               
       //序列化
        Stream stream = File.Open("EmployeeInfo.osl", FileMode.Create);
        BinaryFormatter bformatter = new BinaryFormatter();
               
        Console.WriteLine("Writing Employee Information");
        bformatter.Serialize(stream, mp);
        stream.Close();

mp = null;
       //反序列
        stream = File.Open("EmployeeInfo.osl", FileMode.Open);
        bformatter = new BinaryFormatter();
           
        Console.WriteLine("Reading Employee Information");
        mp = (Employee)bformatter.Deserialize(stream);
        stream.Close();
               
        Console.WriteLine("Employee Id: {0}",mp.EmpId.ToString());
        Console.WriteLine("Employee Name: {0}",mp.EmpName);
        Console.WriteLine("Employee NoSerialString: {0}",mp.NoSerialString);

}
}

执行的结果是:Writing Employee Information
Reading Employee Information
Employee Id: 10
Employee Name: Omkumar
Employee NoSerialString: NoSerialString-Test
 
 看到Employee NoSerialString:属性的值没有,它保持默认值,没有序列化。

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/Sea_Shore/archive/2009/06/26/4301604.aspx

转载于:https://www.cnblogs.com/fsyiyun/archive/2009/11/18/3946989.html

.net c# 序列化和反序列相关推荐

  1. 什么要使用克隆、如何实现克隆对象、序列化与反序列实现克隆的好处、深拷贝与浅拷贝

    1.为什么要使用克隆 对象的拷贝需要使用克隆,如果想对一个对象进行处理,又想保留原有的数据进行接下来的操作,就需要使用克隆了,Java语言中克隆针对的是类的实例. 2.如何实现克隆对象 有两种方式: ...

  2. 第五模块 为什么要使用克隆、如何实现克隆对象、序列化与反序列实现克隆的好处、深拷贝与浅拷贝

    1  为什么要使用克隆 2  如何实现克隆对象 import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; i ...

  3. 【数据结构与算法】之深入解析“序列化和反序列化二叉搜索树”的求解思路与算法示例

    一.题目要求 序列化是将数据结构或对象转换为一系列位的过程,以便它可以存储在文件或内存缓冲区中,或通过网络连接链路传输,以便稍后在同一个或另一个计算机环境中重建. 设计一个算法来序列化和反序列化 二叉 ...

  4. MFC开发IM-第二十四篇、使用 acl 库针对 C++ 对象进行序列化及反序列编程

    在开发网络应用程序时,各个模块之间的数据通信可谓是家常便饭,为了应对这些数据通信时数据交换的要求,程序员发明了各种数据格式:采用二进制数据结构(早期 C 程序员).采用 XML.采用SOAP(坑人的设 ...

  5. C# Json 序列化与反序列化二

    /// <summary>/// 将对象转换为 JSON 字符串/// </summary>/// <typeparam name="T">&l ...

  6. 将对象序列化与反序列实例

    概述: 有些时候我们需要把对象进行序列化或者反序列化,通过System.Runtime.Serialization.Formatters.Binary里的方法即可实现 . 实例如下: Code usi ...

  7. 图片序列化和反序列化成图片文件(代码)

    // // ViewController.m // 图片序列化和反序列化 // // Created by Qlinchao on 17/3/14. // Copyright © 2017年 QLC. ...

  8. leetcode 449. Serialize and Deserialize BST | 449. 序列化和反序列化二叉搜索树(BST后序遍历性质)

    题目 https://leetcode.com/problems/serialize-and-deserialize-bst/ 题解 本题的难点在于 利用 BST 的性质. 几个提示 根据后序遍历BS ...

  9. java序列化的方法_【Java常见序列化与反序列方法总结】

    人和电脑在很多方面都是十分相似的,大脑可以看成电脑主机,五官/身体等表面器官就是显示器.鼠标等外设.这篇文章就是想把计算机跟人做类比YY一下序列化和反序列化的机制.用途. 如果你是初学者,心里肯定会问 ...

最新文章

  1. Linux其实非常好学
  2. 麻省理工正式宣布人工智能独立设系!人工智能与电子工程、计算机科学系将三分天下...
  3. SpringMVC-组件分析之视图解析器(prefix,suffix)
  4. mysql的用户和密码
  5. Office文档模型深入---Outlook文档模型与开发实战(1)
  6. centos下编译安装curl拓展
  7. Android 数据访问之External Storage 数据保存在sd卡 demo+笔记
  8. [转]关于频率、模拟角频率、数字角频率
  9. Pycharm如何打开Django项目
  10. 贴片电阻系列命名标准
  11. 符号——Alt+数字键
  12. 服务器iis建站维护,云服务器iis建站教程
  13. 使用Echarts制作散点图
  14. 浅谈MMORPG服务器架构
  15. 动态仙人掌 系列题解之二——3465: 动态仙人掌 II
  16. SG-UAP电网项目开发简介
  17. 《C语言入门经典》Ivor Horton第十章练习题1
  18. ECharts 异步加载数据及loading 动画
  19. 顺丰王卫回应“快递员遭投诉吞安眠药”:马上检讨 立即整改
  20. XP停止服务:不必难过 千里相送终有一别

热门文章

  1. 拼接图像亮度均匀调整_液晶拼接屏如何才能达到更好的显示效果
  2. 计算机网络-UDP协议
  3. 【数字信号处理】傅里叶变换性质 ( 共轭对称、共轭反对称 与 偶对称、奇对称关联 | 序列对称分解定理 )
  4. 【数字信号处理】基本序列 ( 基本序列列举 | 单位脉冲序列 | 单位脉冲函数 | 离散单位脉冲函数 | 单位脉冲函数 与 离散单位脉冲函数的区别 )
  5. 【Android 逆向】整体加固脱壳 ( DEX 优化流程分析 | DexPrepare.cpp 中 dvmOptimizeDexFile() 方法分析 | /bin/dexopt 源码分析 )
  6. 【开发环境】PyCharm 打开现有 Python 工程 ( 配置 Python 编译器版本 )
  7. 【Flutter】StatefulWidget 组件 ( FloatingActionButton 组件 | RefreshIndicator 组件 )
  8. 【Java 集合】Java 集合主要脉络 ( Collection | Map | List | Set )
  9. 【组合数学】生成函数 简要介绍 ( 生成函数定义 | 牛顿二项式系数 | 常用的生成函数 | 与常数相关 | 与二项式系数相关 | 与多项式系数相关 )
  10. 【Android 应用开发】 Android 相关代码规范 更新中 ...