C# 实现复杂对象的序列化与反序列化[收藏此页] [打印]【IT168知识库】

本文主要是介绍C# 实现复杂对象的序列化与反序列化[收藏此页] [打印]【IT168知识库】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

C# 实现复杂对象的序列化与反序列化

[ 收藏此页] [ 打印]

【IT168知识库】
 

      (注:本篇文章是本人根据msdn,各位同行的心得再加上自己对序列化的一些想法汇集而成,如有不当,还请指教)
     
    序列化是将对象转换为容易传输的格式的过程。例如,可以序列化一个对象,然后使用 HTTP 通过 Internet 在客户端和服务器之间传输该对象。反之,反序列化根据流重新构造对象。这里主要介绍两种序列的方法:一是XML 序列化,二是Binary序列化。

         1.   XML序列

            XML 序列化仅将对象的公共字段和属性值序列化为 XML 流。XML 序列化不包括类型信息。例如,如果 Library 命名空间中有一个 Book 对象,将不能保证它会被反序列化为同一类型的对象。XML 序列化不转换方法、索引器、私有字段或只读属性(只读集合除外)。要序列化对象的所有字段和属性(公共的和私有的),请使用 BinaryFormatter ,而不要使用 XML 序列化.XML 序列化中最主要的类是 XmlSerializer 类,它的最重要的方法是 Serialize 和 Deserialize 方法。我们可以利用它提供这两个方法实现对象的序列与反序列.下面我提供我自己编写的code,主要是用xmlserialize来实现对象的序列与反序列,代码如下:
   
         首先,声明两个用来序列的对象,一个用户设置对象和一个图层参数对象,用户设置对象包括了用户信息和一个图层列表:

 1 /// <summary>
 2    /// 图层参数
 3    /// </summary>

 4     [Serializable]
 5      public   class  LayerPara
 6      {
 7        public int ID;
 8        public string MC;               // 中文名称
 9        public string Layer;            // 数据集名称
10        public short GBCode;            // 分类码
11        public short GeoType;           // 图层对应的几何类型, 11表示点图层,12表示线图层
12        public int MinScale;            // 显示的最小比例尺
13    }

14     [Serializable]
15      public   class  UserSetting
16      {
17        public string strUserName = "kandy";
18        public string strUserPwd = "123456789";
19        public List<LayerPara> userLayerParas;
20    }

21

     然后,声明一个进行序列与反序列的类,其中WriteDataToFile实现将文件写如本地指定的路径,ReadDataFormFile方法实现将文件从磁盘中读取:

class  Serialize
    
{
        
        
public List<UserSetting> m_LayerParamsList;
        
public UserSetting userSetting;
        
public Serialize()
        
{
            
this.ResetLayersInfo();
            
this.WriteDataToFile(userSetting);
        }


        
private void ResetLayersInfo()
        
{
            m_LayerParamsList 
= new List<UserSetting>();

            userSetting 
= new UserSetting();
            userSetting.userLayerParas 
= new List<LayerPara>();
            

            LayerPara layerPara 
= new LayerPara();
            layerPara.ID 
= 100;
            layerPara.MC 
= "管点";
            layerPara.Layer 
= "gd";
            layerPara.GBCode 
= 4;
            layerPara.GeoType 
= 5;
            layerPara.MinScale 
= 100;

            userSetting.userLayerParas.Add(layerPara);

            layerPara.ID 
= 200;
            layerPara.MC 
= "管线";
            layerPara.Layer 
= "gx";
            layerPara.GBCode 
= 5;
            layerPara.GeoType 
= 6;
            layerPara.MinScale 
= 100;

            userSetting.userLayerParas.Add(layerPara);
           
        }


        
private void WriteDataToFile(UserSetting tempUserSetting)
        
{
            
if (tempUserSetting != null)
            
{
                
try
                
{
                    
string strSaveToPath = AppDomain.CurrentDomain.BaseDirectory;
                    strSaveToPath 
= strSaveToPath + "UserLayerSetting.xml";
                    Stream stream 
= new FileStream(strSaveToPath, FileMode.Create, FileAccess.Write, FileShare.ReadWrite);
                    XmlSerializer xmlFormatter 
= new XmlSerializer(typeof(UserSetting));
                    xmlFormatter.Serialize(stream, tempUserSetting);
                    stream.Close();

                    Console.WriteLine(
" serialize is finished!");
                }

                
catch (InvalidOperationException e)
                
{
                    Console.WriteLine(e.Message);
                }

            }

        }


        
public UserSetting ReadDataFormFile()
        
{
            UserSetting setting 
= new UserSetting();
            
string strSaveToPath = AppDomain.CurrentDomain.BaseDirectory;
            strSaveToPath 
= strSaveToPath + "UserLayerSetting.xml";

            
bool isExist = this.IsExsitFileInAppPath(strSaveToPath);
            
if (isExist)
            
{
                Stream stream 
= new FileStream(strSaveToPath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
                XmlSerializer formatter 
= new XmlSerializer(typeof(UserSetting));
                
try
                
{
                    setting 
= (UserSetting)formatter.Deserialize(stream);
                    Console.WriteLine(setting.strUserName);
                    Console.WriteLine(setting.strUserPwd);
                    
foreach(LayerPara lp in setting.userLayerParas)
                    
{
                        Console.WriteLine(lp.ID.ToString());
                        Console.WriteLine(lp.MC);
                        Console.WriteLine(lp.Layer);
                        Console.WriteLine(lp.GBCode.ToString());
                        Console.WriteLine(lp.GeoType.ToString());
                        Console.WriteLine(lp.MinScale);
                        Console.WriteLine(
"/n");
                    }

                }

                
catch (SerializationException e)
                
{
                    Console.WriteLine(e.Message);
                }

            }

            
else
                Console.WriteLine(
"File is not Exist!");

            
return setting;
        }


        
private bool IsExsitFileInAppPath(string strTempPath)
        
{
            
bool bExsit = false;
            bExsit 
= File.Exists(strTempPath);
            
return bExsit;
        }

        
    }

现在我们就可以在Main()方法中进行调用了,下面是一个进行测试的类,包含了主程序的Main()方法:

public   class  Testing
    
{
        
public static void Main()
        
{
            Console.WriteLine(
"Serialize is beginning");

            Serialize serialize 
= new Serialize();
            serialize.ReadDataFormFile();
            Console.WriteLine(
"Read have finished!");
            Console.Read();
            
        }

    }

   2.Binary序列
      这里主要谈的是BinaryFormatter,它位于System.Runtime.Serialization.Formatters.Binary名字空间下,以二进制格式将对象或整个连接对象图形序列化和反序列化。个人认为BinaryFormatter比第一种方法更好用,它同样也有Serialize和DeSerialize方法,具体代码我就贴序列与反序列的代码了,其原理与过程都大致相同,下面是序列与反序列的代码:

private   void  SaveLayerToAppPath(List < LayerPara >  tempLayerParas)
        
{
            
if (tempLayerParas != null)
            
{
                
string strSaveToPath=AppDomain.CurrentDomain.BaseDirectory;
                strSaveToPath
=strSaveToPath+"layer.dat";
                Stream stream 
= new FileStream(strSaveToPath, FileMode.Create, FileAccess.Write, FileShare.None);
                IFormatter formatter 
= new BinaryFormatter();
                formatter.Serialize(stream, tempLayerParas);
                stream.Close();

                Console.WriteLine(
" serialize is success!");
            }

        }


        
public  List < LayerPara >  ReadDataFormFile()
        
{
            List
<LayerPara> tempLayerPara = new List<LayerPara>();

            
string strSaveToPath = AppDomain.CurrentDomain.BaseDirectory;
            strSaveToPath 
= strSaveToPath + "layer.dat";

            
bool isExist = this.IsExsitFileInAppPath(strSaveToPath);
            
if (isExist)
            
{
                Stream stream 
= new FileStream(strSaveToPath, FileMode.Open, FileAccess.Read, FileShare.None);
                BinaryFormatter formatter 
= new BinaryFormatter();

                
try
                
{
                    tempLayerPara 
= (List<LayerPara>)formatter.Deserialize(stream);
                    
foreach (LayerPara lp in tempLayerPara)
                    
{
                        Console.WriteLine(lp.ID.ToString());
                        Console.WriteLine(lp.MC);
                        Console.WriteLine(lp.Layer);
                        Console.WriteLine(lp.GBCode.ToString());
                        Console.WriteLine(lp.GeoType.ToString());
                        Console.WriteLine(lp.MinScale);
                    }

                }

                
catch (SerializationException e)
                
{
                    Console.WriteLine(e.Message);
                }

            }

            
else
                Console.WriteLine(
"File is not Exist!");

            
return tempLayerPara;
        }

   总结:主要是根据的实际项目需要了,看你适合哪种方法.

这篇关于C# 实现复杂对象的序列化与反序列化[收藏此页] [打印]【IT168知识库】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/297683

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭