C#实现的序列化通用类实例

本文实例讲述了C#实现的序列化通用类。分享给大家供大家参考。具体如下:

using System;
using System.IO;
using System.IO.Compression;
using System.Runtime.Serialization.Formatters.Binary;
using System.Runtime.Serialization.Formatters.Soap;
using System.Text;
using System.Xml;
using System.Xml.Serialization;
namespace PlatForm.Utilities
{
 public enum SerializedType : ushort
 {
  ByteArray = 0,
  Object = 1,
  String = 2,
  Datetime = 3,
  Bool = 4,
  //SByte  = 5, //Makes no sense.
  Byte = 6,
  Short = 7,
  UShort = 8,
  Int = 9,
  UInt = 10,
  Long = 11,
  ULong = 12,
  Float = 13,
  Double = 14,
  CompressedByteArray = 255,
  CompressedObject = 256,
  CompressedString = 257,
 }
 public class SerializeHelper
 {
  public SerializeHelper()
  { }
  #region XML序列化
  /// <summary>
  /// 文件化XML序列化
  /// </summary>
  /// <param name="obj">对象</param>
  /// <param name="filename">文件路径</param>
  public static void Save(object obj, string filename)
  {
   FileStream fs = null;
   try
   {
    fs = new FileStream(filename, FileMode.Create, FileAccess.Write, FileShare.ReadWrite);
    XmlSerializer serializer = new XmlSerializer(obj.GetType());
    serializer.Serialize(fs, obj);
   }
   catch (Exception ex)
   {
    throw ex;
   }
   finally
   {
    if (fs != null) fs.Close();
   }
  }
  /// <summary>
  /// 文件化XML反序列化
  /// </summary>
  /// <param name="type">对象类型</param>
  /// <param name="filename">文件路径</param>
  public static object Load(Type type, string filename)
  {
   FileStream fs = null;
   try
   {
    fs = new FileStream(filename, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
    XmlSerializer serializer = new XmlSerializer(type);
    return serializer.Deserialize(fs);
   }
   catch (Exception ex)
   {
    throw ex;
   }
   finally
   {
    if (fs != null) fs.Close();
   }
  }
  /// <summary>
  /// 文本化XML序列化
  /// </summary>
  /// <param name="item">对象</param>
  public string ToXml<T>(T item)
  {
   XmlSerializer serializer = new XmlSerializer(item.GetType());
   StringBuilder sb = new StringBuilder();
   using (XmlWriter writer = XmlWriter.Create(sb))
   {
    serializer.Serialize(writer, item);
    return sb.ToString();
   }
  }
  /// <summary>
  /// 文本化XML反序列化
  /// </summary>
  /// <param name="str">字符串序列</param>
  public T FromXml<T>(string str)
  {
   XmlSerializer serializer = new XmlSerializer(typeof(T));
   using (XmlReader reader = new XmlTextReader(new StringReader(str)))
   {
    return (T)serializer.Deserialize(reader);
   }
  }
  #endregion
  #region SoapFormatter序列化
  /// <summary>
  /// SoapFormatter序列化
  /// </summary>
  /// <param name="item">对象</param>
  public static string ToSoap<T>(T item)
  {
   SoapFormatter formatter = new SoapFormatter();
   using (MemoryStream ms = new MemoryStream())
   {
    formatter.Serialize(ms, item);
    ms.Position = 0;
    XmlDocument xmlDoc = new XmlDocument();
    xmlDoc.Load(ms);
    return xmlDoc.InnerXml;
   }
  }
  /// <summary>
  /// SoapFormatter反序列化
  /// </summary>
  /// <param name="str">字符串序列</param>
  public static T FromSoap<T>(string str)
  {
   XmlDocument xmlDoc = new XmlDocument();
   xmlDoc.LoadXml(str);
   SoapFormatter formatter = new SoapFormatter();
   using (MemoryStream ms = new MemoryStream())
   {
    xmlDoc.Save(ms);
    ms.Position = 0;
    return (T)formatter.Deserialize(ms);
   }
  }
  #endregion
  #region BinaryFormatter序列化
  /// <summary>
  /// BinaryFormatter序列化
  /// </summary>
  /// <param name="item">对象</param>
  public static string ToBinary<T>(T item)
  {
   BinaryFormatter formatter = new BinaryFormatter();
   using (MemoryStream ms = new MemoryStream())
   {
    formatter.Serialize(ms, item);
    ms.Position = 0;
    byte[] bytes = ms.ToArray();
    StringBuilder sb = new StringBuilder();
    foreach (byte bt in bytes)
    {
     sb.Append(string.Format("{0:X2}", bt));
    }
    return sb.ToString();
   }
  }
  /// <summary>
  /// BinaryFormatter反序列化
  /// </summary>
  /// <param name="str">字符串序列</param>
  public static T FromBinary<T>(string str)
  {
   int intLen = str.Length / 2;
   byte[] bytes = new byte[intLen];
   for (int i = 0; i < intLen; i++)
   {
    int ibyte = Convert.ToInt32(str.Substring(i * 2, 2), 16);
    bytes[i] = (byte)ibyte;
   }
   BinaryFormatter formatter = new BinaryFormatter();
   using (MemoryStream ms = new MemoryStream(bytes))
   {
    return (T)formatter.Deserialize(ms);
   }
  }
  #endregion
  /// <summary>
  /// 将对象序列化为二进制字节
  /// </summary>
  /// <param name="obj">待序列化的对象</param>
  /// <returns></returns>
  public static byte[] SerializeToBinary(object obj)
  {
   byte[] bytes = new byte[2500];
   using (MemoryStream memoryStream = new MemoryStream())
   {
    BinaryFormatter bformatter = new BinaryFormatter();
    bformatter.Serialize(memoryStream, obj);
    memoryStream.Seek(0, 0);
    if (memoryStream.Length > bytes.Length)
    {
     bytes = new byte[memoryStream.Length];
    }
    bytes = memoryStream.ToArray();
   }
   return bytes;
  }
  /// <summary>
  /// 从二进制字节中反序列化为对象
  /// </summary>
  /// <param name="type">对象的类型</param>
  /// <param name="bytes">字节数组</param>
  /// <returns>反序列化后得到的对象</returns>
  public static object DeserializeFromBinary(Type type, byte[] bytes)
  {
   object result = new object();
   using (MemoryStream memoryStream = new MemoryStream(bytes))
   {
    BinaryFormatter serializer = new BinaryFormatter();
    result = serializer.Deserialize(memoryStream);
   }
   return result;
  }
  /// <summary>
  /// 将文件对象序列化到文件中
  /// </summary>
  /// <param name="obj">待序列化的对象</param>
  /// <param name="path">文件路径</param>
  /// <param name="fileMode">文件打开模式</param>
  public static void SerializeToBinary(object obj, string path, FileMode fileMode)
  {
   using (FileStream fs = new FileStream(path, fileMode))
   {
    // Construct a BinaryFormatter and use it to serialize the data to the stream.
    BinaryFormatter formatter = new BinaryFormatter();
    formatter.Serialize(fs, obj);
   }
  }
  /// <summary>
  /// 将文件对象序列化到文件中
  /// </summary>
  /// <param name="obj">待序列化的对象</param>
  /// <param name="path">文件路径</param>
  public static void SerializeToBinary(object obj, string path)
  {
   SerializeToBinary(obj, path, FileMode.Create);
  }
  /// <summary>
  /// 从二进制文件中反序列化为对象
  /// </summary>
  /// <param name="type">对象的类型</param>
  /// <param name="path">二进制文件路径</param>
  /// <returns>反序列化后得到的对象</returns>
  public static object DeserializeFromBinary(Type type, string path)
  {
   object result = new object();
   using (FileStream fileStream = new FileStream(path, FileMode.Open))
   {
    BinaryFormatter serializer = new BinaryFormatter();
    result = serializer.Deserialize(fileStream);
   }
   return result;
  }
  /// <summary>
  /// 获取对象的转换为二进制的字节大小
  /// </summary>
  /// <param name="obj"></param>
  /// <returns></returns>
  public static long GetByteSize(object obj)
  {
   long result;
   BinaryFormatter bFormatter = new BinaryFormatter();
   using (MemoryStream stream = new MemoryStream())
   {
    bFormatter.Serialize(stream, obj);
    result = stream.Length;
   }
   return result;
  }
  /// <summary>
  /// 克隆一个对象
  /// </summary>
  /// <param name="obj">待克隆的对象</param>
  /// <returns>克隆的一个新的对象</returns>
  public static object Clone(object obj)
  {
   object cloned = null;
   BinaryFormatter bFormatter = new BinaryFormatter();
   using (MemoryStream memoryStream = new MemoryStream())
   {
    try
    {
     bFormatter.Serialize(memoryStream, obj);
     memoryStream.Seek(0, SeekOrigin.Begin);
     cloned = bFormatter.Deserialize(memoryStream);
    }
    catch //(Exception e)
    {
     ;
    }
   }
   return cloned;
  }
  /// <summary>
  /// 从文件中读取文本内容
  /// </summary>
  /// <param name="path">文件路径</param>
  /// <returns>文件的内容</returns>
  public static string ReadFile(string path)
  {
   string content = string.Empty;
   using (StreamReader reader = new StreamReader(path))
   {
    content = reader.ReadToEnd();
   }
   return content;
  }
  public static byte[] Serialize(object value, out SerializedType type, uint compressionThreshold)
  {
   byte[] bytes;
   if (value is byte[])
   {
    bytes = (byte[])value;
    type = SerializedType.ByteArray;
    if (bytes.Length > compressionThreshold)
    {
     bytes = compress(bytes);
     type = SerializedType.CompressedByteArray;
    }
   }
   else if (value is string)
   {
    bytes = Encoding.UTF8.GetBytes((string)value);
    type = SerializedType.String;
    if (bytes.Length > compressionThreshold)
    {
     bytes = compress(bytes);
     type = SerializedType.CompressedString;
    }
   }
   else if (value is DateTime)
   {
    bytes = BitConverter.GetBytes(((DateTime)value).Ticks);
    type = SerializedType.Datetime;
   }
   else if (value is bool)
   {
    bytes = new byte[] { (byte)((bool)value ? 1 : 0) };
    type = SerializedType.Bool;
   }
   else if (value is byte)
   {
    bytes = new byte[] { (byte)value };
    type = SerializedType.Byte;
   }
   else if (value is short)
   {
    bytes = BitConverter.GetBytes((short)value);
    type = SerializedType.Short;
   }
   else if (value is ushort)
   {
    bytes = BitConverter.GetBytes((ushort)value);
    type = SerializedType.UShort;
   }
   else if (value is int)
   {
    bytes = BitConverter.GetBytes((int)value);
    type = SerializedType.Int;
   }
   else if (value is uint)
   {
    bytes = BitConverter.GetBytes((uint)value);
    type = SerializedType.UInt;
   }
   else if (value is long)
   {
    bytes = BitConverter.GetBytes((long)value);
    type = SerializedType.Long;
   }
   else if (value is ulong)
   {
    bytes = BitConverter.GetBytes((ulong)value);
    type = SerializedType.ULong;
   }
   else if (value is float)
   {
    bytes = BitConverter.GetBytes((float)value);
    type = SerializedType.Float;
   }
   else if (value is double)
   {
    bytes = BitConverter.GetBytes((double)value);
    type = SerializedType.Double;
   }
   else
   {
    //Object
    using (MemoryStream ms = new MemoryStream())
    {
     new BinaryFormatter().Serialize(ms, value);
     bytes = ms.GetBuffer();
     type = SerializedType.Object;
     if (bytes.Length > compressionThreshold)
     {
      bytes = compress(bytes);
      type = SerializedType.CompressedObject;
     }
    }
   }
   return bytes;
  }
  private static byte[] compress(byte[] bytes)
  {
   using (MemoryStream ms = new MemoryStream())
   {
    using (DeflateStream gzs = new DeflateStream(ms, CompressionMode.Compress, false))
    {
     gzs.Write(bytes, 0, bytes.Length);
    }
    ms.Close();
    return ms.GetBuffer();
   }
  }
  private static byte[] decompress(byte[] bytes)
  {
   using (MemoryStream ms = new MemoryStream(bytes, false))
   {
    using (DeflateStream gzs = new DeflateStream(ms, CompressionMode.Decompress, false))
    {
     using (MemoryStream dest = new MemoryStream())
     {
      byte[] tmp = new byte[bytes.Length];
      int read;
      while ((read = gzs.Read(tmp, 0, tmp.Length)) != 0)
      {
       dest.Write(tmp, 0, read);
      }
      dest.Close();
      return dest.GetBuffer();
     }
    }
   }
  }
  public static object DeSerialize(byte[] bytes, SerializedType type)
  {
   switch (type)
   {
    case SerializedType.String:
     return Encoding.UTF8.GetString(bytes);
    case SerializedType.Datetime:
     return new DateTime(BitConverter.ToInt64(bytes, 0));
    case SerializedType.Bool:
     return bytes[0] == 1;
    case SerializedType.Byte:
     return bytes[0];
    case SerializedType.Short:
     return BitConverter.ToInt16(bytes, 0);
    case SerializedType.UShort:
     return BitConverter.ToUInt16(bytes, 0);
    case SerializedType.Int:
     return BitConverter.ToInt32(bytes, 0);
    case SerializedType.UInt:
     return BitConverter.ToUInt32(bytes, 0);
    case SerializedType.Long:
     return BitConverter.ToInt64(bytes, 0);
    case SerializedType.ULong:
     return BitConverter.ToUInt64(bytes, 0);
    case SerializedType.Float:
     return BitConverter.ToSingle(bytes, 0);
    case SerializedType.Double:
     return BitConverter.ToDouble(bytes, 0);
    case SerializedType.Object:
     using (MemoryStream ms = new MemoryStream(bytes))
     {
      return new BinaryFormatter().Deserialize(ms);
     }
    case SerializedType.CompressedByteArray:
     return DeSerialize(decompress(bytes), SerializedType.ByteArray);
    case SerializedType.CompressedString:
     return DeSerialize(decompress(bytes), SerializedType.String);
    case SerializedType.CompressedObject:
     return DeSerialize(decompress(bytes), SerializedType.Object);
    case SerializedType.ByteArray:
    default:
     return bytes;
   }
  }
 }
}

希望本文所述对大家的C#程序设计有所帮助。

(0)

相关推荐

  • c#对象反序列化与对象序列化示例详解

    1.对象序列化的介绍 (1).NET支持对象序列化的几种方式二进制序列化:对象序列化之后是二进制形式的,通过BinaryFormatter类来实现的,这个类位于System.Runtime.Serialization.Formatters.Binary命名空间下.SOAP序列化:对象序列化之后的结果符合SOAP协议,也就是可以通过SOAP 协议传输,通过System.Runtime.Serialization.Formatters.Soap命名空间下的SoapFormatter类来实现的.XML

  • 用序列化实现List<T> 实例的深复制(推荐)

    如果 List<T> 里的 T 是引用类型(如myClass类),则在 像这种写法: List<myClass> lists1 = new List<myClass>() { new myClass(), new myClass() }; List<myClass> lists2 = new List<myClass>(lists1 ); 其实是一个浅复制的过程. 如果要实现深复制,通过有几种做法,可以用foreach, 或者重写Clone()方

  • .NET的深复制方法(以C#语言为例)

    很多时候我们复制一个对象实例A到实例B,在用实例B去做其他事情的时候,会对实例B进行修改,为保证对B的修改不会影响到A的正常使用,就需要使用到深复制. 我在网上搜到一些深复制的方法,同时写了几组例子对这些方法进行测试. 我的操作系统版本为Win7旗舰版,.NET Framework版本是4.5 测试程序 我建了一个C#窗体应用程序(Winform),其主窗口FormMain的Load函数内容如下: private void FormMain_Load(object sender, EventAr

  • C#实现json的序列化和反序列化实例代码

    在做asp.net和unity进行http通信的时候,当unity客户端发出表单请求的时候,我要将他要请求的数据以json的格式返回给客户端,让客户端来解析.服务器端这一块就涉及到json的序列化和反序列化的问题. 两种方法都有例子,第一种是用泛型集合来存储的对象,然后将集合序列化一下:第二种是直接序列化的一个对象 复制代码 代码如下: using System;using System.Collections.Generic;using System.Web.Script.Serializat

  • C#复制和深度复制的实现方法

    深度复制与浅表复制的区别在于,浅表复制只复制值类型的值,而对于实例所包含的对象依然指向原有实例. class Program { [Serializable] public class Car { public string name; public Car(string name) { this.name = name; } } [Serializable] public class Person:ICloneable { public int id; public string name;

  • C#实现的序列化通用类实例

    本文实例讲述了C#实现的序列化通用类.分享给大家供大家参考.具体如下: using System; using System.IO; using System.IO.Compression; using System.Runtime.Serialization.Formatters.Binary; using System.Runtime.Serialization.Formatters.Soap; using System.Text; using System.Xml; using Syste

  • C#操作Access通用类实例

    本文实例讲述了C#操作Access通用类.分享给大家供大家参考.具体如下: using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using Syst

  • C#导出数据到CSV文件的通用类实例

    本文实例讲述了C#导出数据到csv文件的通用类.分享给大家供大家参考.具体如下: 通过这个类可以很简单的定义数据格式,并导出到csv文件 //这里写了一个通用的类 using System; using System.Data; using System.Configuration; using System.Collections.Generic; using System.Web; using System.Web.Security; using System.Web.UI; using S

  • iOS base64 加密解密 通用类实例代码

    在使用过程中,直接将被类引入到项目中即可,不需要其它辅助类. 使用示例:  将此通用类的头文件引入到目标类后,直接使用类名进行调用即可. NSString *str = [NSString stringWithFormat:@"YWE="]; NSString *str1 = [NSString stringWithFormat:@"aa"]; NSLog(@"resultStr========%@",[CommonFunc textFromBa

  • springboot日志切面通用类实例详解

    1.pom.xml文件导入AOP依赖 <!--aop依赖--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> <version>2.3.0.RELEASE</version> </dependency> 2.pom.xml导入Lombo

  • C#实现DataSet内数据转化为Excel和Word文件的通用类完整实例

    本文实例讲述了C#实现DataSet内数据转化为Excel和Word文件的通用类.分享给大家供大家参考,具体如下: 前不久因为项目的需要写的一个C#把DataSet内数据转化为Excel和Word文件的通用类,这些关于Excel.Word的导出方法,基本可以实现日常须要,其中有些方法可以把数据导出后 生成Xml格式,再导入数据库!有些屏蔽内容没有去掉,保留下来方便学习参考用之. 最后请引用Office相应COM组件,导出Excel对象的一个方法要调用其中的一些方法和属性. using Syste

  • Java对象的XML序列化与反序列化实例解析

    上一篇文章我们介绍了java实现的各种排序算法代码示例,本文我们看看Java对象的xml序列化与反序列化的相关内容,具体如下. XML是一种标准的数据交换规范,可以方便地用于在应用之间交换各类数据.如果能在Java对象和XML文档之间建立某种映射,例如Java对象的XML序列化和反序列化,那么就可以使Java的对象方便地与其他应用进行交换. java.beans包里面有两个类XMLEncoder和Decoder,分别用于将符合JabaBeans规范的Java对象以XML方式序列化和反序列化.以下

  • Java 序列化和反序列化实例详解

    Java 序列化和反序列化实例详解 在分布式应用中,对象只有经过序列化才能在各个分布式组件之间传输,这就涉及到两个方面的技术-发送者将对象序列化,接受者将对象反序列化,下面就是一个很好的例子! 1.实体-Employee import java.io.Serializable; public class Employee implements Serializable{ /** * */ private static final long serialVersionUID = 1L; publi

  • SpringBoot整合MyBatis逆向工程及 MyBatis通用Mapper实例详解

    一.添加所需依赖,当前完整的pom文件如下: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd&q

  • Java集合ArrayDeque类实例分析

    Java集合ArrayDeque类实例分析 前言 ArrayDeque类是双端队列的实现类,类的继承结构如下面,继承自AbastractCollection(该类实习了部分集合通用的方法,其实现了Collection接口),其实现的接口Deque接口中定义了双端队列的主要的方法,比如从头删除,从尾部删除,获取头数据,获取尾部数据等等. public class ArrayDeque<E> extends AbstractCollection<E> implements Deque&

随机推荐