设计之初就需要考虑的要点有
1.数据结构是否支持Web Service
2.是否需要支持持久化对象为XML结构,与Contract持久化并不冲突,是一种补充
3.当.net对象垮远程边界时,考虑支持runtime持久化
4.当只需要普通持久化时,避免使用XML和Runtime技术。
XML Serial
用了Dotnet那么久还几乎没用过Serial技术,惭愧。
将内存流修改为文件流,再进行下面的测试,可以得到相同的结果。
类可以更复杂,特殊的情况需要添加特定的Attribute进行特殊的定义。以上
1.数据结构是否支持Web Service
2.是否需要支持持久化对象为XML结构,与Contract持久化并不冲突,是一种补充
3.当.net对象垮远程边界时,考虑支持runtime持久化
4.当只需要普通持久化时,避免使用XML和Runtime技术。
XML Serial
用了Dotnet那么久还几乎没用过Serial技术,惭愧。
open System
open System.IO
[<CLIMutable>]//这里必须添加此特性,让这个Recode带有一个默认的构造函数
type DateSerTest =
{
Local:DateTime;
Utc:DateTime
}
let ser = new System.Xml.Serialization.XmlSerializer(typeof<DateSerTest>)
let d = {
Local = DateTime.SpecifyKind(new DateTime(2014, 10, 1), DateTimeKind.Local)
Utc = DateTime.SpecifyKind(new DateTime(2014, 10, 1), DateTimeKind.Utc)
}
let testSerialization(dt:DateSerTest) =
use ms = new IO.MemoryStream()
ser.Serialize(ms, o = dt)
let result = Text.Encoding.Default.GetString(ms.GetBuffer())
ms.Close()
result
let objecblock = testSerialization d//从内存流中取得Xml字节流,流是数据是媒介,Serializer是模板。
let ms = new IO.MemoryStream(Text.Encoding.Unicode.GetBytes(objecblock))
let newd = ser.Deserialize(ms) :?> DateSerTest//生成对象
if d = newd then prrintfn "Equal"将内存流修改为文件流,再进行下面的测试,可以得到相同的结果。
let testFileSerialization(dt:DateSerTest) =
let filename = "serialization.xml"
use ms = new StreamWriter(filename)
ser.Serialize(ms, o = dt)
ms.Close()
testFileSerialization d
let ms = new StreamReader("serialization.xml")
let newd = ser.Deserialize(ms) :?> DateSerTest
if d = newd then printfn "Equal"类可以更复杂,特殊的情况需要添加特定的Attribute进行特殊的定义。以上
本文介绍了一个简单的.NET XML序列化示例,演示了如何通过使用XMLSerializer来序列化和反序列化自定义类型。同时讨论了在设计阶段需要考虑的数据结构支持问题。
1628

被折叠的 条评论
为什么被折叠?



