VB.NET对象串行化实现过程简述

开发 后端
VB.NET对象串行化的主要过程可以理解为对一个对象进行存储。而返串行化则是创建一个新的相等的对象实例。而且串行化在VB.NET中还是自动的。

我们可以通过对VB.NET中的对象进行一系列的操作来达到我们的目的。比如VB.NET对象串行化的实现就是一个比较常用的操作步骤。从中我们可以了解到对象操作在实际程序代码中的重要性。#t#

只要我们运用对象,我们就需要存储它们的表现形式。也许我们暂时不需要一个对象,我们不想让它散乱地放在内存中。或者我们可能需要把一个对象实例从一个系统传送到另一个系统。

对于所有这些情况,对象的状态就需要以某种形式来体现,可以以不定的形式保存起来,或者传送到另一个系统。通常,我们把对象的状态信息作为一系列数据字节来存储。

存储一个对象状态的过程就叫做VB.NET对象串行化。运用这个状态信息来创建一个新的、相等的对象实例就叫做“反串行化”。在VB6及更早的版本中,你必须编写你自己的逻辑来执行这些操作。尽管有这么多编程工作要做,但串行化在.NET中是自动的。

如果你在一个类的前面放一个属性,那么一个对象实例就可以自动地被串行化了。你将这个属性放置在一个类的声明部分,如下: _
Public Class MyClassName

你也可以通过实现一个叫做ISerializable的接口来串行化一个对象,但这种方法更复杂。在大多数情况下,运用属性更容易,也很有效。

一旦一个类被标记了属性,我们就可以存储它的状态了。如果你运用另一个叫做Formatter的类,你可以将一个.NET对象实例的状态作为一系列字节存储起来,可以存储在磁盘上或一个数据库中,可以运用.NET Remoting或消息队列从一个系统传送到另一个系统。然后,另外的那个Formatter类就可以从串行化的状态信息“重建”对象实例了。

不同类型的VB.NET对象串行化有不同的Formatter类。BinaryFormatter保存一个对象的所有的内部状态,包括私有变量。这就叫做“深串行化(deep serialization)”。XMLFormatter只保存公有属性和数据成员,这个过程叫做“浅串行化(shallow serialization)”。还有用于其它目的的formatters。运用何种formatter取决于你的对象是否有重建对象实例所必须的内部状态信息,以及你打算用串行化信息做什么。

Formatter对象有Serialize和Deserialize方法。Serialize方法有两个参数——一个放置状态信息字节的对象流和要被串行化的对象实例。Deserizlize方法对包含状态信息字节的对象流进行处理并将新的重建的对象实例作为一个普通的Object类型返回。然后,我们可以用CType方法将新的实例转化成适当的类型。

因此,要想把你的对象信息存储到磁盘上的一个文件,你可能需要下面的逻辑:

  1. Dim myFileStream As New _  
  2. FileStream("C:\MyFileName.
    dat", _  
  3. FileMode.CreateNew)  
  4. Dim MyFormatter As New
     BinaryFormatter()  
  5. MyFormatter.Serialize
    (myFileStream, MyObject) 

然后你可以用这个逻辑来重建对象:

  1. Dim myFileStream As New _  
  2. FileStream("C:\MyFileName.dat", _  
  3. FileMode.Open)  
  4. Dim MyFormatter As New 
    BinaryFormatter()  
  5. Dim GenericObject As Object  
  6. GenericObject = _ 
  7. MyFormatter.Deserialize
    (myFileStream)  
  8. Dim MyObject As MyObjectType  
  9. MyObject = CType(GenericObject, 
    MyObjectType) 

这时候,你就可以用这个对象了,它的行为同最初的对象实例的行为完全一样。

有时侯,VB.NET对象串行化的过程是自动的。例如,如果把一个对象实例放在一个消息队列上,消息队列上的实际数据是由从串行化对象而来的状态信息字节组成的。MessageQueue对象有一个Formatter属性来指定所运用的formatter类型。这就简化了把一个对象放到一个消息队列上的过程,只需一行代码:

  1. MessageQueue1.Send
    (objMyObjectInstance, _  
  2. "A tag string for 
    humans to read") 

 

然后,另一个系统就可以从队列上提取状态信息,并创建一个相等的对象实例了。那个系统也必须有一个MessageQueue对象,它的Formatter属性也必须同用来将信息放到队列上的最初的MessageQueue对象的formatter属性类型一致。

这有一点复杂。你需要两个步骤:

  1.  MyQueueMessage = _ 
  2. MessageQueue1.Receive
    (ATimeoutValue)  
  3. objMyReconstitutedInstance = _ 
  4. CType(MyQueueMessage.Body, _  
  5. MyObjectsType) 

第一步是从消息队列提取VB.NET对象串行化状态信息,第二步是运用该信息来创建新的、相等的对象实例。然后,我们就可以像运用最初的对象实例一样来运用新的对象了。

还有更多关于处理消息队列的资料,例如如何来处理超时设定。MSDN上的一篇名为“The Queue Continuum”的文章讲述了这方面的一些细节。然而,正如你所看到的,将对象串行化到消息队列上以及反串行化来得到一个新的对象实例是很简单的。

责任编辑:曹凯 来源: 博客园
相关推荐

2009-11-02 16:41:55

VB.NET串行化对象

2010-01-14 18:00:07

VB.NET串行化对象

2010-01-12 10:48:54

VB.NET LIST

2009-10-20 17:38:20

VB.NET exce

2009-11-04 08:53:57

VB.NET AddH

2009-11-18 11:05:27

PHP串行化

2010-01-07 13:51:50

VB.NET数组赋值

2010-01-20 18:10:27

VB.NET访问级别

2010-01-14 17:03:01

VB.NET获取网卡地

2009-10-09 15:59:41

VB.NET对象

2009-10-14 13:21:46

VB.NET Acco

2010-01-21 09:53:55

VB.NET获取程序运

2010-01-15 15:03:23

VB.NET对象变量声

2010-01-15 15:39:14

VB.NET Sub过

2010-01-22 18:24:28

VB.NET重构

2010-01-12 11:17:21

VB.NET文字特效

2009-10-23 16:43:01

VB.NET绘制图形

2010-01-19 14:42:43

VB.NET调用过程重

2009-10-30 11:20:54

VB.NET Proc

2010-01-12 18:05:38

VB.NET对象
点赞
收藏

51CTO技术栈公众号