C((zhi)序列化技術の詳細解(转)
プロローグと反プロローグはよく耳にするかもしれませんが、実は分かりやすい説明です.
を選択します.プログレッシブとは、オブジェクトをファイルまたはデータベースフィールドに保存し、逆プログレッシブとは、適切なときにこのファイルを元のオブジェクトに再変換して使うことです.
プロローグと反プロローグの最も主要な役割は:
1
、次のプロセスの起動時に前回保存したオブジェクトの情報を読みだします.
2
違います
アプリDomain
またはプロセス間のデータ転送
3
、分散アプリケーションでデータを転送する
……
はい、
同前
の一般的な序列化の方法は主に3つあります.
Binary Formater
を選択します
SoappFormater
を選択します
XML
序文化
この文章は一つの例を通して、この3つの方法の具体的な使用と異同点について説明します.
この例は三つの違った方法で一つを使うことです.
Book
オブジェクトは、序列化と反序列化を行います.もちろん、これは
Book
クラスはまず順序化されます.
Book
クラス
using System;
using System.Collections;
using System.Text;
namespace SerializableTest
{
[Serializable]
public class Book
{
public Book()
{
alBookReader = new ArrayList();
}
public string strBookName;
[NonSerialized]
public string strBookPwd;
private string _bookID;
public string BookID
{
get { return _bookID; }
set { _bookID = value; }
}
public ArrayList alBookReader;
private string _bookPrice;
public void SetBookPrice(string price)
{
_bookPrice = price;
}
public void Write()
{
Console.WriteLine("Book ID:" + BookID);
Console.WriteLine("Book Name:" + strBookName);
Console.WriteLine("Book Password:" + strBookPwd);
Console.WriteLine("Book Price:" + _bookPrice);
Console.WriteLine("Book Reader:");
for (int i = 0; i < alBookReader.Count; i++)
{
Console.WriteLine(alBookReader[i]);
}
}
}
}
この類は比較的簡単ですが、いくつか定義されています.public
フィールドと読み書きの属性、一つ
prvate
フィールドとしてマークされています.
[NonSerialized]
のフィールドは、具体的に次の例に現れます.
一、Binary Formaterプログレッシブ方式
1
プロローグとは
Book
クラスの割り当てを行い、ファイルに順序付けを行います.
Book book = new Book();
book.BookID = "1";
book.alBookReader.Add("gspring");
book.alBookReader.Add(" ");
book.strBookName = "C# ";
book.strBookPwd = "*****";
book.SetBookPrice("50.00");
BinarySerialize serialize = new BinarySerialize();
serialize.Serialize(book);
2、反プロローグBinarySerialize serialize = new BinarySerialize();
Book book = serialize.DeSerialize();
book.Write();
3、テスト用のBinary Serialize類using System;
using System.Collections.Generic;
using System.Text;
using System.IO;
using System.Runtime.Serialization.Formatters.Binary;
namespace SerializableTest
{
public class BinarySerialize
{
string strFile = "c:""book.data";
public void Serialize(Book book)
{
using (FileStream fs = new FileStream(strFile, FileMode.Create))
{
BinaryFormatter formatter = new BinaryFormatter();
formatter.Serialize(fs, book);
}
}
public Book DeSerialize()
{
Book book;
using (FileStream fs = new FileStream(strFile, FileMode.Open))
{
BinaryFormatter formatter = new BinaryFormatter();
book = (Book)formatter.Deserialize(fs);
}
return book;
}
}
}
主にSystem.Runtime.Serialization.Formaters.Binaryの空間の下のBinary Formater類を呼び出して序列化と逆序列化を行い、縮略型のバイナリ形式で一つのファイルに書くと、スピードが比較的速いです.そして書き込み後のファイルはすでにバイナリに一定の秘密保護効果が保存されています.アンチプログレッシブを呼び出した後のスクリーンショットは以下の通りです.つまり、NonSerializedと表記されている他のメンバーはすべてプログレッシブ二、SoappFormaterプログレッシブ方式でプログレッシブとアンチプログレッシブを呼び出す方法は上記と比較して似ています.using System;
using System.Collections.Generic;
using System.Text;
using System.IO;
using System.Runtime.Serialization.Formatters.Soap;
namespace SerializableTest
{
public class SoapSerialize
{
string strFile = "c:""book.soap";
public void Serialize(Book book)
{
using (FileStream fs = new FileStream(strFile, FileMode.Create))
{
SoapFormatter formatter = new SoapFormatter();
formatter.Serialize(fs, book);
}
}
public Book DeSerialize()
{
Book book;
using (FileStream fs = new FileStream(strFile, FileMode.Open))
{
SoapFormatter formatter = new SoapFormatter();
book = (Book)formatter.Deserialize(fs);
}
return book;
}
}
}
主にSystem.Runtime.Serialization.Formators.Soap空間のSoapp Formater類を呼び出して序列化とアンチプログレッシブを行います.使う前にSystem.Runtime.Serialization.Formaters.Soap.dll(.netが持参している)プログレッシブ後のファイルは簡単なファイルです.は、軽くて簡単で、XMLに基づくプロトコルであり、WEB上で構造化された情報と固化された情報を交換するように設計されています. SOAPは、既存の多くのインターネットプロトコルとフォーマットを組み合わせて使用することができ、超テキスト転送プロトコル(HTTP)、簡単メール転送プロトコル(SMTP)、多用途インターネットメール拡張プロトコル(MIME)を含む.また、メッセージシステムから遠隔プロセス呼び出し(RPC)などの大規模なアプリケーションプログラムをサポートする.SOAPは、XMLに基づくデータ構造と超テキスト転送プロトコル(HTTP)を使用する.の組み合わせで定義されている標準的な方法は、インターネット上のさまざまな操作環境の分散オブジェクトを使用しています.)アンチプログレッシブを呼び出した後の結果と方法は同じです.XMLプログレッシブ方式でプログレッシブとアンチプログレッシブを呼び出す方法は上記と比較して類似しています.Xml Serialize類XmlSerialize類を見てみます.using System;
using System.Collections.Generic;
using System.Text;
using System.IO;
using System.Xml.Serialization;
namespace SerializableTest
{
public class XmlSerialize
{
string strFile = "c:""book.xml";
public void Serialize(Book book)
{
using (FileStream fs = new FileStream(strFile, FileMode.Create))
{
XmlSerializer formatter = new XmlSerializer(typeof(Book));
formatter.Serialize(fs, book);
}
}
public Book DeSerialize()
{
Book book;
using (FileStream fs = new FileStream(strFile, FileMode.Open))
{
XmlSerializer formatter = new XmlSerializer(typeof(Book));
book = (Book)formatter.Deserialize(fs);
}
return book;
}
}
}
これらの3つのテストクラスから見てもいいですが、3つの方法の呼び出しはほとんど同じです.具体的に使う種類が違っています.xmlプログレッシブ後のファイルは一般的な一つのxmlファイルです.book.xmlファイルです.<?xml version="1.0"?>
<Book xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<strBookName>C# </strBookName>
<strBookPwd>*****</strBookPwd>
<alBookReader>
<anyType xsi:type="xsd:string">gspring</anyType>
<anyType xsi:type="xsd:string"> </anyType>
</alBookReader>
<BookID>1</BookID>
</Book>
出力スクリーンは以下の通りです.つまり、xmlのプログレッシブ方式では、publicのフィールドと読み書き可能な属性しか保存できません.privteなどのタイプのフィールドについては、プログレッシブ化はできません.循環参照については、上記の例のBookクラスに次のような属性を追加します. public Book relationBook;プログレッシブを呼び出すときは、次のような方法があります.Book book = new Book();
book.BookID = "1";
book.alBookReader.Add("gspring");
book.alBookReader.Add(" ");
book.strBookName = "C# ";
book.strBookPwd = "*****";
book.SetBookPrice("50.00");
Book book2 = new Book();
book2.BookID = "2";
book2.alBookReader.Add("gspring");
book2.alBookReader.Add(" ");
book2.strBookName = ".NET ";
book2.strBookPwd = "*****";
book2.SetBookPrice("40.00");
book.relationBook = book2;
book2.relationBook = book;
BinarySerialize serialize = new BinarySerialize();
serialize.Serialize(book);
, BinarySerialize SoapSerialize (.NET ), XmlSerialize :" SerializableTest.Book 。"