共用方式為


基本序列化

要讓類別可序列化最簡單的方式就是以 Serializable 屬性加以標示,如下所示。

[Serializable]
public class MyObject {
  public int n1 = 0;
  public int n2 = 0;
  public String str = null;
}

以下的程式碼範例顯示此類別的執行個體序列化成檔案的方式。

MyObject obj = new MyObject();
obj.n1 = 1;
obj.n2 = 24;
obj.str = "Some String";
IFormatter formatter = new BinaryFormatter();
Stream stream = new FileStream("MyFile.bin", FileMode.Create, FileAccess.Write, FileShare.None);
formatter.Serialize(stream, obj);
stream.Close();

此範例使用二進位格式子進行序列化。您僅需建立資料流的執行個體,以及想使用的格式子,然後呼叫格式子上的 Serialize 方法。將要序列化的資料流及物件,當做參數提供給此呼叫。雖然在此範例中未明確示範,不過類別的所有成員變數都將序列化,即使是標示為私用的變數亦然。在這方面,二進位序列化與 XMLSerializer 類別不同,後者只序列化公用欄位。如需關於從二進位序列化排除成員變數的詳細資訊,請參閱選擇式序列化

將物件還原成其先前的狀態也一樣容易。首先,建立供讀取的資料流和格式子,然後指示格式子對物件還原序列化。下列程式碼範例會示範其做法。

IFormatter formatter = new BinaryFormatter();
Stream stream = new FileStream("MyFile.bin", FileMode.Open, FileAccess.Read, FileShare.Read);
MyObject obj = (MyObject) formatter.Deserialize(stream);
stream.Close();

// Here's the proof.
Console.WriteLine("n1: {0}", obj.n1);
Console.WriteLine("n2: {0}", obj.n2);
Console.WriteLine("str: {0}", obj.str);

上述使用的 BinaryFormatter 非常有效率,可產生精簡的位元組資料流。利用此格式子序列化的所有物件也可以用它來還原序列化,所以此格式子是理想的工具,可以在 .NET Framework 上對將要還原序列化的物件進行序列化。務必注意,物件還原序列化時,不會呼叫建構函式。還原序列化有此限制是基於效能的考量。然而,這樣違反了執行階段與物件寫入器之間建立的某些一般合約,開發人員應確定他們了解將物件標示為可序列化時,可能出現的後果。

如果要求可攜性,請改為使用 SoapFormatter。只要將上述程式碼中的 BinaryFormatter 替換為 SoapFormatter,並如之前一樣呼叫 SerializeDeserialize 即可。在上述範例中使用的此格式子會產生下列輸出。

<SOAP-ENV:Envelope
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns:xsd="http://www.w3.org/2001/XMLSchema" 
  xmlns:SOAP- ENC="https://schemas.xmlsoap.org/soap/encoding/"
  xmlns:SOAP- ENV="https://schemas.xmlsoap.org/soap/envelope/"
  SOAP-ENV:encodingStyle=
  "https://schemas.microsoft.com/soap/encoding/clr/1.0"
  "https://schemas.xmlsoap.org/soap/encoding/"
  xmlns:a1="https://schemas.microsoft.com/clr/assem/ToFile">

  <SOAP-ENV:Body>
    <a1:MyObject id="ref-1">
      <n1>1</n1>
      <n2>24</n2>
      <str id="ref-3">Some String</str>
    </a1:MyObject>
  </SOAP-ENV:Body>
</SOAP-ENV:Envelope>

請注意,Serializable 屬性無法被繼承。若您從 MyObject 衍生新類別,新類別必須也用該屬性標示,否則無法將其序列化。例如,當您嘗試序列化下列類別的執行個體時,會出現 SerializationException 通知您 MyStuff 型別未標示為可序列化。

public class MyStuff : MyObject 
{
  public int n3;
}

使用 Serializable 屬性很方便,但有上述限制。如需何時應將類別標示為序列化的資訊,請參閱序列化方針;類別在編譯後即不能加入序列化。

另請參閱

其他資源

二進位序列化
Remote Objects
XML 和 SOAP 序列化