.net精简框架集多个类同时串行化(XML方式)技术

简介:        存取类实例的参数最佳的方法当然是串行化技术,串行化支持两种方式:二进制方式,可以高保真的保存类示例,另一种是XML方式,它仅保存公共数据。

       存取类实例的参数最佳的方法当然是串行化技术,串行化支持两种方式:二进制方式,可以高保真的保存类示例,另一种是XML方式,它仅保存公共数据。很可惜.net 2.0的精简框架集仅支持XML方式。

      我这里做了一个示例,实现的功能是在PC机上可以画很多图形,用串行化方式保存相关信息,把相关信息下载到wince中,由wince中的c#程序读取串行化信息,并把相关类的实例信息还原出来。

     这里面有个关键,图形类有可能有多个(示例为2个),而目前我查相关资料,都是一个类的串行化存取,并且如果你存两个以上的类,用XML是可以存取成功的,但是读取的时候它会告诉你失败。所以这里引入了ArrayList类的相关概念。

      也就是说,我定义了一个类,类中的一个属性为ArrayList类的实例,这样用ArrayList实例我可以存储很多的类信息。

      同样,不作任何处理用一般方法存储是成功的,但是在读取时,你发现ArrayList实例中的数据,都是object类型,原类型信息丢失!

      这怎么办?继续查资料,发现有两种方法可以解决这个问题。

      1、  [XmlElement(Type = typeof(YFRect)), XmlElement(Type = typeof(YFCircle))]
              public ArrayList gData = new ArrayList();          //图元数据

              在类中添加XmlElement声明,把ArrayList 类实例中有可能添加的类都标示出。

       2、在存取数据时,用代码告诉XML串行化相关类的类型

              Type[] gt = new Type[2];   //图元类型数组
            gt[0] = typeof(YFRect);
            gt[1] = typeof(YFCircle);
           
            Stream sf = new FileStream(strXmlFile, FileMode.Open, FileAccess.Read, FileShare.None);
            XmlSerializer xmls = new XmlSerializer(typeof(YFGraphicsData), gt);
            XmlData = (YFGraphicsData)xmls.Deserialize(sf);
            sf.Close();

      这是运行后的结果:

 

相关代码:clsGraphics.cs    (图元类)

using System;
using System.Collections.Generic;
using System.Text;
using System.Collections;
using System.Drawing;
using System.Xml.Serialization;
using System.IO;
using System.Xml;

namespace YFXMLSaveLoad
{  
    //图元数据类
    public class YFGraphicsData
    {
        //[XmlElement(Type = typeof(YFRect)), XmlElement(Type = typeof(YFCircle))]
        //当代码传入类型数组时,则不需要上面的声明
        public string strName = "测试";
        public string strVer = "V1.0.0";
        public ArrayList gData = new ArrayList();          //图元数据
      
    }

    //串行化操作类
    public class YFXMLSerialize
    {
        //串行化
        public void XMLSerializer(YFGraphicsData XmlData,string strXmlFile)
        {
            Type[] gt = new Type[2];  //图元类型数组
            gt[0] = typeof(YFRect);
            gt[1] = typeof(YFCircle);

            Stream sf = new FileStream(strXmlFile, FileMode.Create, FileAccess.Write, FileShare.None);
            XmlSerializer xmls = new XmlSerializer(typeof(YFGraphicsData), gt);
            xmls.Serialize(sf, XmlData);
            sf.Close();
        }

        //反串行化
        public void XMLDeserialize(out YFGraphicsData XmlData, string strXmlFile)
        {
            Type[] gt = new Type[2];   //图元类型数组
            gt[0] = typeof(YFRect);
            gt[1] = typeof(YFCircle);
           
            Stream sf = new FileStream(strXmlFile, FileMode.Open, FileAccess.Read, FileShare.None);
            XmlSerializer xmls = new XmlSerializer(typeof(YFGraphicsData), gt);
            XmlData = (YFGraphicsData)xmls.Deserialize(sf);
            sf.Close();
        }      
 
    }
   
    //------------------------------------------------
    public class YFGraphicsBase
    {    
        public int  width = 1;
        //Color类不支持XML串行化
        public int color = 0;  
        public virtual void Draw(Graphics e) { }
    }

    public class YFRect : YFGraphicsBase
    {
        public Rectangle xy;
        public override void Draw(Graphics e)
        {
            e.DrawRectangle(new Pen(Color.FromArgb(color), width), xy);
        }
    }

    public class YFCircle : YFGraphicsBase
    {
        public Rectangle xy;      
        public override void Draw(Graphics e)
        {
            e.DrawEllipse(new Pen(Color.FromArgb(color), width), xy);
        }
    }
   
}

Form1.cs 窗体代码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Collections;
using System.Xml.Serialization;
using System.IO;
using System.Reflection;
using System.Runtime.InteropServices;

namespace YFXMLSaveLoad
{
    public partial class Form1 : Form
    {

        YFGraphicsData XmlData = new YFGraphicsData();    //图元数据
        YFXMLSerialize XmlWork = new YFXMLSerialize();    //XML串行化方法

        public Form1()
        {
            InitializeComponent();
            panel1.Refresh();
        }

        //自绘
        private void button4_Click(object sender, EventArgs e)
        {
            YFRect yfr001=new YFRect();
            YFRect  yfr002 = new YFRect();
            YFCircle yfc001 = new YFCircle();

            yfr001.color = Color.Blue.ToArgb(); 
            yfr001.xy.X  = 10;
            yfr001.xy.Y   = 10;
            yfr001.xy.Width  = 50;
            yfr001.xy.Height   = 50;

            yfr002.color = Color.FromArgb(0, 0, 0).ToArgb();
            yfr002.width = 2;
            yfr002.xy.X = 30;
            yfr002.xy.Y = 50;
            yfr002.xy.Width = 100;
            yfr002.xy.Height = 80;

            yfc001.color = Color.Red.ToArgb();
            yfc001.xy.X = 20;
            yfc001.xy.Y = 20;
            yfc001.xy.Width = 80;
            yfc001.xy.Height = 90;

            XmlData.gData.Clear();
            XmlData.gData.Add(yfr001);
            XmlData.gData.Add(yfc001);
            XmlData.gData.Add(yfr002);

            panel1.Refresh();           

        }  

        //绘图
        private void panel1_Paint(object sender, PaintEventArgs e)
        {
            e.Graphics.Clear(Color.PapayaWhip);
            foreach (YFGraphicsBase dw in XmlData.gData)
            {
                dw.Draw(e.Graphics);              
            }
            textBox1.Text = XmlData.gData.Count.ToString();
        }

        //清图元
        private void button3_Click(object sender, EventArgs e)
        {
            XmlData.gData.Clear();
            panel1.Refresh();
        }

        //保存图元
        private void button2_Click(object sender, EventArgs e)
        {
            //图元串行化
            XmlWork.XMLSerializer(XmlData,"TuData.xml");
            //------
            MessageBox.Show("OK"); 
        }

        //调入图元
        private void button1_Click(object sender, EventArgs e)
        {
            //图元反串行化
            XmlWork.XMLDeserialize(out XmlData, "TuData.xml");
            //------ 
            panel1.Refresh();
        }    

    }
}

//-----------------------------------

 

相关文章
|
26天前
|
设计模式 开发框架 JavaScript
基于.NET8 + Vue/UniApp前后端分离的快速开发框架,开箱即用!
基于.NET8 + Vue/UniApp前后端分离的快速开发框架,开箱即用!
|
3天前
|
消息中间件 开发框架 监控
NET任务调度框架Hangfire使用指南
Hangfire 是一个用于 .NET 应用程序的开源任务调度框架,支持长时间运行任务、定时任务等。通过简单的安装配置,即可将任务从主线程分离,提升应用性能。支持多种数据库,提供丰富的任务类型如立即执行、延迟执行和周期性任务,并有可视化管理界面 Hangfire Dashboard。还支持安全性配置及扩展插件,如 Hangfire.HttpJob,适合各种复杂场景下的任务调度需求。
21 1
NET任务调度框架Hangfire使用指南
|
23天前
|
自然语言处理 物联网 图形学
.NET 技术凭借其独特的优势和特性,为开发者们提供了一种高效、可靠且富有创造力的开发体验
本文深入探讨了.NET技术的独特优势及其在多个领域的应用,包括企业级应用、Web应用、桌面应用、移动应用和游戏开发。通过强大的工具集、高效的代码管理、跨平台支持及稳定的性能,.NET为开发者提供了高效、可靠的开发体验,并面对技术更新和竞争压力,不断创新发展。
35 7
|
22天前
|
开发框架 安全 .NET
在数字化时代,.NET 技术凭借跨平台兼容性、丰富的开发工具和框架、高效的性能及强大的安全稳定性,成为软件开发的重要支柱
在数字化时代,.NET 技术凭借跨平台兼容性、丰富的开发工具和框架、高效的性能及强大的安全稳定性,成为软件开发的重要支柱。它不仅加速了应用开发进程,提升了开发质量和可靠性,还促进了创新和业务发展,培养了专业人才和技术社区,为软件开发和数字化转型做出了重要贡献。
24 5
|
22天前
|
传感器 人工智能 供应链
.NET开发技术在数字化时代的创新作用,从高效的开发环境、强大的性能表现、丰富的库和框架资源等方面揭示了其关键优势。
本文深入探讨了.NET开发技术在数字化时代的创新作用,从高效的开发环境、强大的性能表现、丰富的库和框架资源等方面揭示了其关键优势。通过企业级应用、Web应用及移动应用的创新案例,展示了.NET在各领域的广泛应用和巨大潜力。展望未来,.NET将与新兴技术深度融合,拓展跨平台开发,推动云原生应用发展,持续创新。
27 4
|
22天前
|
开发框架 .NET C#
.NET 技术凭借高效开发环境、强大框架支持及跨平台特性,在软件开发中占据重要地位
.NET 技术凭借高效开发环境、强大框架支持及跨平台特性,在软件开发中占据重要地位。从企业应用到电子商务,再到移动开发,.NET 均展现出卓越性能,助力开发者提升效率与项目质量,推动行业持续发展。
24 4
|
23天前
|
机器学习/深度学习 人工智能 物联网
.NET 技术:引领未来开发潮流
.NET 技术以其跨平台兼容性、高效的开发体验、强大的性能表现和安全可靠的架构,成为引领未来开发潮流的重要力量。本文深入探讨了 .NET 的核心优势与特点,及其在企业级应用、移动开发、云计算、人工智能等领域的广泛应用,展示了其卓越的应用价值和未来发展前景。
52 5
|
22天前
|
机器学习/深度学习 人工智能 Cloud Native
在数字化时代,.NET 技术凭借其跨平台兼容性、丰富的类库和工具集以及卓越的性能与效率,成为软件开发的重要平台
在数字化时代,.NET 技术凭借其跨平台兼容性、丰富的类库和工具集以及卓越的性能与效率,成为软件开发的重要平台。本文深入解析 .NET 的核心优势,探讨其在企业级应用、Web 开发及移动应用等领域的应用案例,并展望未来在人工智能、云原生等方面的发展趋势。
29 3
|
22天前
|
敏捷开发 缓存 中间件
.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素
本文深入探讨了.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素,并通过企业级应用和Web应用开发的实践案例,展示了如何在实际项目中应用这些模式,旨在为开发者提供有益的参考和指导。
21 3
|
22天前
|
开发框架 安全 Java
.NET技术的独特魅力与优势,涵盖高效的开发体验、强大的性能表现、高度的可扩展性及丰富的生态系统等方面,展示了其在软件开发领域的核心竞争力
本文深入探讨了.NET技术的独特魅力与优势,涵盖高效的开发体验、强大的性能表现、高度的可扩展性及丰富的生态系统等方面,展示了其在软件开发领域的核心竞争力。.NET不仅支持跨平台开发,具备出色的安全性和稳定性,还能与多种技术无缝集成,为企业级应用提供全面支持。
27 3