.NET 对象序列化

今天在寫類的時候,編譯出現如下的錯誤:我寫的類必須標記為可序列化.

找了半天的錯誤,結果發現為:寫的類必須標記為可序列化的,為什么呢?

在網上找了點文章,如下

什么是序列化?
  .net的运行时环境用来支持用户定义类型的流化的机制。它是将对象实例的状态存储到存储媒体的过程。在序列化的过程中,先将对象的公共字段和私有字 段以及类的名称(包括类所在的程序集)转换为字节流,然后再把字节流写入数据流。在随后对对象进行反序列化时,将创建出与原对象完全相同的副本。
序列化可以给我们带来什么样的方便之处呢?
         1.持久存储
        有时我们经常需要将对象的字段值保存到磁盘中,以便在以后检索此数据。虽然没有序列化也可以完成这项工作,但其方法往往是很繁琐而且容易出错的,并且在需 要跟踪对象的层次结构时,会变得越来越麻烦。我们可以想 象一下编写包含大量对象的大型业务应用程序的情形,程序员不得不为每一个对象编写代码,以便将字段和属性保存至磁盘或从磁盘还原这些字段和属性。不过序列 化就不一样了,它提供了轻松实现这个目标的快捷方法。
         公共语言运行时(CLR)管理对象在内存中的分布,.NET框架则通过使用反射提供自动的序列化机制。对象被序列化后,类的名称、程序集以及类实例的所有 数据成员均被写入存储媒体中。对象通常用成员变量来存储对其他实例的引用。类序列化后,序列化引擎将跟踪所有已序列的引用对象,这样就确保了同一对象不被 序列化多次。.NET框架所提供的序列化体系结构可以自动正确处理对象图表和循环引用。对对象图表的唯一要求是,由正在进行序列化的对象所引用的所有对象 都必须标记为Serializable。否则序列化程序试图序列化未标记的对象时将为出现异常。Serializable属性用来明确表示该类可以被序列 化。同样的,我们可以用NonSerializable属性用来明确表示类不能被序列化。
这样反序列化已序列化的类时,将重新创建该类,并还原所有数据成员的值。
         2.按值封送
        对象仅在创建对象的应用程序域中有效。除非对象是从MarshalByRefObject派生得到或标记为Serializable,否则,任何将对象作 为参数传递或将其作为结果返回的尝试都将失败。如果对象标记为 Serializable,则该对象将被自动序列化,并从一个应用程序域传输至另一个应用程序域,然后进行反序列化,从而在第二个应用程序域中产生出该对 象的一个精确副本。此过程通常称为按值封送。
序列化的实现
         序列化的机制是将类的值转化为一般的字节流,然后把这个流存储到存储媒介上。.NET框架里提供了这样两个类 BinaryFormatter和SoapFormatter。BinaryFormatter使用二进制格式化程序进行序列化。它将类中的所有成员变量 (甚至标记为 private 的变量)都序列化。而SoapFormatter使用XML格式化,因此会有更好的可移植性。
下面是BinaryFormatter序列化和反序列化

基本序列化
         要使一个类可序列化,最简单的方法是使用 Serializable 属性对它进行标记,如下所示:

[Serializable]
public class ObjectSerializable
{
    
public int s1 = 0 ;
    
public int s2 = 0 ;
    
public String str = null ;
}

好,原因已經找到了,我的類就是需要按值封送,不然按如上所述就肯定會出錯.問題解決了很是開心,哈哈哈

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值