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

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、