XmlChoiceIdentifierAttribute クラス
アセンブリ: System.Xml (system.xml.dll 内)

<AttributeUsageAttribute(AttributeTargets.Property Or AttributeTargets.Field Or AttributeTargets.Parameter Or AttributeTargets.ReturnValue, AllowMultiple:=False)> _ Public Class XmlChoiceIdentifierAttribute Inherits Attribute
[AttributeUsageAttribute(AttributeTargets.Property|AttributeTargets.Field|AttributeTargets.Parameter|AttributeTargets.ReturnValue, AllowMultiple=false)] public class XmlChoiceIdentifierAttribute : Attribute
[AttributeUsageAttribute(AttributeTargets::Property|AttributeTargets::Field|AttributeTargets::Parameter|AttributeTargets::ReturnValue, AllowMultiple=false)] public ref class XmlChoiceIdentifierAttribute : public Attribute

xsi:choice という名前の XML スキーマ要素定義を使用すると、その子のうちの 1 つだけをインスタンスに含めることのできる (maxoccurs = 1) 複合要素を定義できます。インスタンスに含めることのできる子は、いくつかの型のいずれかになり、その名前もいくつかの名前のうちの 1 つになります。それぞれの名前は特定の型に関連付けられますが、いくつかの名前を同じ型に関連付けることもできます。したがって、このような要素のインスタンスはあいまいになります。このようなあいまいな要素の例として、MyChoice という名前の要素を定義するスキーマ フラグメントを次に示します。
<xsd:complexType name="MyChoice"> <xsd:sequence> <xsd:choice minOccurs="0" maxOccurs="1"> <xsd:element minOccurs="1" maxOccurs="1" name="ChoiceOne" type="xsd:string" /> <xsd:element minOccurs="1" maxOccurs="1" name="ChoiceTwo" type="xsd:string" /> </xsd:choice> </xsd:sequence> </xsd:complexType>
XmlChoiceIdentifierAttribute を使用すると、メンバの各インスタンスに特定の列挙値を割り当てることができます。列挙体は独自に作成するか、XML スキーマ定義ツール (Xsd.exe) を使用して作成する必要があります。次の C# コードでは、XmlChoiceIdentifierAttribute を Item フィールドに適用する方法を示しています。その MemberName プロパティには、メンバのインスタンスを検出するために使用する列挙体を格納しているフィールドが指定されています。
public class Choices{ [XmlChoiceIdentifier("ItemType")] [XmlChoiceIdentifier("ChoiceOne")] [XmlChoiceIdentifier("ChoiceTwo")] public string MyChoice; // Do not serialize this next field: [XmlIgnore] public ItemChoiceType ItemType; } // Do not include this enumeration in the XML schema. [XmlType(IncludeInSchema = false)] public enum ItemChoiceType{ ChoiceOne, ChoiceTwo, }
このコードを正しい場所に記述すると、ItemType フィールドに適切な列挙体を設定することによって、このクラスをシリアル化および逆シリアル化できます。たとえば、Choice クラスをシリアル化するための C# コードは、次のようになります。
Choices mc = new Choices(); mc.MyChoice = "Item Choice One"; mc.ItemType = ItemChoiceType.ChoiceOne;
MyChoice mc = (MyChoice) myXmlSerializer.Deserialize(myReader); if(mc.ItemType == ItemChoiceType.ChoiceOne) { // Handle choice one. } if(mc.ItemType == ItemChoiceType.ChoiceTwo) { // Handle choice two. } if(mc.ItemType != null) { throw CreateUnknownTypeException(mc.Item); }
XmlChoiceIdentifierAttribute の用途は、もう 1 つあります。次のスキーマでは、メンバは、項目の配列 (maxOccurs="unbounded") を返すフィールドです。この配列には、最初の要素 ("D-a-t-a") と 2 番目の要素 ("MoreData") のオブジェクトを格納できます。
<xsd:complexType name="MyChoice"> <xsd:sequence> <xsd:choice minOccurs="0" maxOccurs="unbounded"> <xsd:element minOccurs="1" maxOccurs="1" name="D-a-t-a" type="xsd:string" /> <xsd:element minOccurs="1" maxOccurs="1" name="MoreData" type="xsd:string" /> </xsd:choice> </xsd:sequence> </xsd:complexType>
結果として生成されたクラスは、このフィールドを使用して項目の配列を返します。配列の各項目について、ItemChoiceType 列挙体の値が対応している必要があります。この対応している列挙値が、ItemsElementName フィールドによって返される配列に格納されています。
public class MyChoice { [System.Xml.Serialization.XmlElementAttribute("D-a-t-a", typeof(string), IsNullable=false)] [System.Xml.Serialization.XmlElementAttribute("MoreData", typeof(string), IsNullable=false)] [System.Xml.Serialization.XmlChoiceIdentifierAttribute("ItemsElementName")] public string[] Items; [System.Xml.Serialization.XmlElementAttribute(IsNullable=false)] [System.Xml.Serialization.XmlIgnoreAttribute()] public ItemsChoiceType[] ItemsElementName; } [System.Xml.Serialization.XmlTypeAttribute(IncludeInSchema=false)] public enum ItemsChoiceType { [System.Xml.Serialization.XmlEnumAttribute("D-a-t-a")] Data, MoreData, }
一定範囲内の複数の choice 要素を含んでいるオブジェクトを逆シリアル化するときは、制御構造 (if...then...else 構造など) を使用して、特定の値を逆シリアル化する方法を決定します。この制御構造では、列挙値を調べ、その結果に基づいて値を逆シリアル化します。

MyChoice と ManyChoices という 2 つのフィールドを含んでいる Choices という名前のクラスをシリアル化する例を次に示します。各フィールドに XmlChoiceIdentifierAttribute が適用されており、これらのフィールドは、MemberName プロパティを使用して、それぞれのメンバの値を検出するための列挙体を取得または設定する別のクラス メンバを指定しています。MyChoice フィールドには、対応する列挙体メンバが EnumType フィールド内に存在している単一の値を設定できます。ManyChoices フィールドは、オブジェクトの配列を返します。ChoiceArray フィールドは、列挙値の配列を返します。ManyChoices フィールドの各配列メンバに対応するメンバが、ChoiceArray フィールドによって返される配列の中に見つかります。
Imports System Imports System.Xml Imports System.Xml.Serialization Imports System.IO Public Class Choices ' The MyChoice field can be set to any one of ' the types below. <XmlChoiceIdentifier("EnumType"), _ XmlElement("Word", GetType(String)), _ XmlElement("Number", GetType(Integer)), _ XmlElement("DecimalNumber", GetType(double))> _ Public MyChoice As Object ' Don't serialize this field. The EnumType field ' contains the enumeration value that corresponds ' to the MyChoice field value. <XmlIgnore> _ Public EnumType As ItemChoiceType 'The ManyChoices field can contain an array ' of choices. Each choice must be matched to ' an array item in the ChoiceArray field. <XmlChoiceIdentifier("ChoiceArray"), _ XmlElement("Item", GetType(string)), _ XmlElement("Amount", GetType(Integer)), _ XmlElement("Temp", GetType(double))> _ Public ManyChoices() As Object ' TheChoiceArray field contains the enumeration ' values, one for each item in the ManyChoices array. <XmlIgnore> _ Public ChoiceArray() As MoreChoices End Class <XmlType(IncludeInSchema:=false)> _ Public Enum ItemChoiceType None Word Number DecimalNumber End Enum <XmlType(IncludeInSchema:=false)> _ Public Enum MoreChoices None Item Amount Temp End Enum Public Class Test Shared Sub Main() Dim t As Test = New Test() t.SerializeObject("Choices.xml") t.DeserializeObject("Choices.xml") End Sub private Sub SerializeObject(filename As string) Dim mySerializer As XmlSerializer = _ New XmlSerializer(GetType(Choices)) Dim writer As TextWriter = New StreamWriter(filename) Dim myChoices As Choices = New Choices() ' Set the MyChoice field to a string. Set the ' EnumType to Word. myChoices.MyChoice= "Book" myChoices.EnumType = ItemChoiceType.Word ' Populate an object array with three items, one ' of each enumeration type. Set the array to the ' ManyChoices field. Dim strChoices () As Object = New object(){"Food", 5, 98.6} myChoices.ManyChoices=strChoices ' For each item in the ManyChoices array, add an ' enumeration value. Dim itmChoices () As MoreChoices = New MoreChoices() _ {MoreChoices.Item, _ MoreChoices.Amount, _ MoreChoices.Temp} myChoices.ChoiceArray=itmChoices mySerializer.Serialize(writer, myChoices) writer.Close() End Sub private Sub DeserializeObject(filename As string) Dim ser As XmlSerializer = New XmlSerializer(GetType(Choices)) ' A FileStream is needed to read the XML document. Dim fs As FileStream = New FileStream(filename, FileMode.Open) Dim myChoices As Choices = CType(ser.Deserialize(fs), Choices) fs.Close() ' Disambiguate the MyChoice value Imports the enumeration. if myChoices.EnumType = ItemChoiceType.Word Then Console.WriteLine("Word: " & _ myChoices.MyChoice.ToString()) else if myChoices.EnumType = ItemChoiceType.Number Then Console.WriteLine("Number: " & _ myChoices.MyChoice.ToString()) else if myChoices.EnumType = ItemChoiceType.DecimalNumber Then Console.WriteLine("DecimalNumber: " & _ myChoices.MyChoice.ToString()) End If ' Disambiguate the ManyChoices values Imports the enumerations. Dim i As Integer for i = 0 to myChoices.ManyChoices.Length -1 if myChoices.ChoiceArray(i) = MoreChoices.Item Then Console.WriteLine("Item: " + _ myChoices.ManyChoices(i).ToString()) else if myChoices.ChoiceArray(i) = MoreChoices.Amount Then Console.WriteLine("Amount: " + _ myChoices.ManyChoices(i).ToString()) else if (myChoices.ChoiceArray(i) = MoreChoices.Temp) Console.WriteLine("Temp: " + _ myChoices.ManyChoices(i).ToString()) End If Next i End Sub End Class
using System; using System.Xml; using System.Xml.Serialization; using System.IO; public class Choices{ // The MyChoice field can be set to any one of // the types below. [XmlChoiceIdentifier("EnumType")] [XmlElement("Word", typeof(string))] [XmlElement("Number", typeof(int))] [XmlElement("DecimalNumber", typeof(double))] public object MyChoice; // Don't serialize this field. The EnumType field // contains the enumeration value that corresponds // to the MyChoice field value. [XmlIgnore] public ItemChoiceType EnumType; // The ManyChoices field can contain an array // of choices. Each choice must be matched to // an array item in the ChoiceArray field. [XmlChoiceIdentifier("ChoiceArray")] [XmlElement("Item", typeof(string))] [XmlElement("Amount", typeof(int))] [XmlElement("Temp", typeof(double))] public object[] ManyChoices; // TheChoiceArray field contains the enumeration // values, one for each item in the ManyChoices array. [XmlIgnore] public MoreChoices[] ChoiceArray; } [XmlType(IncludeInSchema=false)] public enum ItemChoiceType{ None, Word, Number, DecimalNumber } public enum MoreChoices{ None, Item, Amount, Temp } public class Test{ static void Main(){ Test t = new Test(); t.SerializeObject("Choices.xml"); t.DeserializeObject("Choices.xml"); } private void SerializeObject(string filename){ XmlSerializer mySerializer = new XmlSerializer(typeof(Choices)); TextWriter writer = new StreamWriter(filename); Choices myChoices = new Choices(); // Set the MyChoice field to a string. Set the // EnumType to Word. myChoices.MyChoice= "Book"; myChoices.EnumType = ItemChoiceType.Word; // Populate an object array with three items, one // of each enumeration type. Set the array to the // ManyChoices field. object[] strChoices = new object[]{"Food", 5, 98.6}; myChoices.ManyChoices=strChoices; // For each item in the ManyChoices array, add an // enumeration value. MoreChoices[] itmChoices = new MoreChoices[] {MoreChoices.Item, MoreChoices.Amount, MoreChoices.Temp}; myChoices.ChoiceArray=itmChoices; mySerializer.Serialize(writer, myChoices); writer.Close(); } private void DeserializeObject(string filename){ XmlSerializer ser = new XmlSerializer(typeof(Choices)); // A FileStream is needed to read the XML document. FileStream fs = new FileStream(filename, FileMode.Open); Choices myChoices = (Choices) ser.Deserialize(fs); fs.Close(); // Disambiguate the MyChoice value using the enumeration. if(myChoices.EnumType == ItemChoiceType.Word){ Console.WriteLine("Word: " + myChoices.MyChoice.ToString()); } else if(myChoices.EnumType == ItemChoiceType.Number){ Console.WriteLine("Number: " + myChoices.MyChoice.ToString()); } else if(myChoices.EnumType == ItemChoiceType.DecimalNumber){ Console.WriteLine("DecimalNumber: " + myChoices.MyChoice.ToString()); } // Disambiguate the ManyChoices values using the enumerations. for(int i = 0; i<myChoices.ManyChoices.Length; i++){ if(myChoices.ChoiceArray[i] == MoreChoices.Item) Console.WriteLine("Item: " + (string) myChoices.ManyChoices[i]); else if(myChoices.ChoiceArray[i] == MoreChoices.Amount) Console.WriteLine("Amount: " + myChoices.ManyChoices[i].ToString()); if(myChoices.ChoiceArray[i] == MoreChoices.Temp) Console.WriteLine("Temp: " + (string) myChoices.ManyChoices[i].ToString()); } } }
#using <System.dll> #using <System.xml.dll> using namespace System; using namespace System::Xml; using namespace System::Xml::Serialization; using namespace System::IO; [XmlType(IncludeInSchema=false)] public enum class ItemChoiceType { None, Word, Number, DecimalNumber }; public enum class MoreChoices { None, Item, Amount, Temp }; public ref class Choices { public: // The MyChoice field can be set to any one of // the types below. [XmlChoiceIdentifier("EnumType")] [XmlElement("Word",String::typeid)] [XmlElement("Number",Int32::typeid)] [XmlElement("DecimalNumber",Double::typeid)] Object^ MyChoice; // Don't serialize this field. The EnumType field // contains the enumeration value that corresponds // to the MyChoice field value. [XmlIgnore] ItemChoiceType EnumType; // The ManyChoices field can contain an array // of choices. Each choice must be matched to // an array item in the ChoiceArray field. [XmlChoiceIdentifier("ChoiceArray")] [XmlElement("Item",String::typeid)] [XmlElement("Amount",Int32::typeid)] [XmlElement("Temp",Double::typeid)] array<Object^>^ManyChoices; // TheChoiceArray field contains the enumeration // values, one for each item in the ManyChoices array. [XmlIgnore] array<MoreChoices>^ChoiceArray; }; void SerializeObject( String^ filename ); void DeserializeObject( String^ filename ); int main() { SerializeObject( "Choices.xml" ); DeserializeObject( "Choices.xml" ); } void SerializeObject( String^ filename ) { XmlSerializer^ mySerializer = gcnew XmlSerializer( Choices::typeid ); TextWriter^ writer = gcnew StreamWriter( filename ); Choices^ myChoices = gcnew Choices; // Set the MyChoice field to a string. Set the // EnumType to Word. myChoices->MyChoice = "Book"; myChoices->EnumType = ItemChoiceType::Word; // Populate an object array with three items, one // of each enumeration type. Set the array to the // ManyChoices field. array<Object^>^strChoices = {"Food",5,98.6}; myChoices->ManyChoices = strChoices; // For each item in the ManyChoices array, add an // enumeration value. array<MoreChoices>^ itmChoices = {MoreChoices::Item,MoreChoices::Amount ,MoreChoices::Temp}; myChoices->ChoiceArray = itmChoices; mySerializer->Serialize( writer, myChoices ); writer->Close(); } void DeserializeObject( String^ filename ) { XmlSerializer^ ser = gcnew XmlSerializer( Choices::typeid ); // A FileStream is needed to read the XML document. FileStream^ fs = gcnew FileStream( filename,FileMode::Open ); Choices^ myChoices = safe_cast<Choices^>(ser->Deserialize( fs )); fs->Close(); // Disambiguate the MyChoice value using the enumeration. if ( myChoices->EnumType == ItemChoiceType::Word ) { Console::WriteLine( "Word: {0}", myChoices->MyChoice->ToString() ); } else if ( myChoices->EnumType == ItemChoiceType::Number ) { Console::WriteLine( "Number: {0}", myChoices->MyChoice->ToString() ); } else if ( myChoices->EnumType == ItemChoiceType::DecimalNumber ) { Console::WriteLine( "DecimalNumber: {0}", myChoices->MyChoice->ToString() ); } // Disambiguate the ManyChoices values using the enumerations. for ( int i = 0; i < myChoices->ManyChoices->Length; i++ ) { if ( myChoices->ChoiceArray[ i ] == MoreChoices::Item ) Console::WriteLine( "Item: {0}", myChoices->ManyChoices[ i ] ); else if ( myChoices->ChoiceArray[ i ] == MoreChoices::Amount ) Console::WriteLine( "Amount: ", myChoices->ManyChoices[ i ]->ToString() ); if ( myChoices->ChoiceArray[ i ] == MoreChoices::Temp ) Console::WriteLine( "Temp: {0}", myChoices->ManyChoices[ i ]->ToString() ); } }
import System.*; import System.Xml.*; import System.Xml.Serialization.*; import System.IO.*; public class Choices { // The myChoice field can be set to any one of // the types below. /** @attribute XmlElement("word", String.class) */ /** @attribute XmlElement("Number", int.class) */ /** @attribute XmlElement("DecimalNumber", double.class) */ public Object myChoice; // Don't serialize this field. The EnumType field // contains the enumeration value that corresponds // to the myChoice field value. public int enumType; // The manyChoices field can contain an array // of choices. Each choice must be matched to // an array item in the choiceArray field. /** @attribute XmlElement("Item", String.class) */ /** @attribute XmlElement("amount", int.class) */ /** @attribute XmlElement("temp", double.class) */ public Object manyChoices[]; // ThechoiceArray field contains the enumeration // values, one for each item in the manyChoices array. public int choiceArray[]; } //Choices /** @attribute XmlType(IncludeInSchema = false) */ public class ItemChoiceType { public static final int none = 0; public static final int word = 1; public static final int number = 2; public static final int decimalNumber = 3; } //ItemChoiceType public class MoreChoices { public static final int none = 0; public static final int item = 1; public static final int amount = 2; public static final int temp = 3; } //MoreChoices public class Test { public static void main(String[] args) { Test t = new Test(); t.SerializeObject("Choices.xml"); t.DeserializeObject("Choices.xml"); } //main private void SerializeObject(String fileName) { XmlSerializer mySerializer = new XmlSerializer(Choices.class.ToType()); TextWriter writer = new StreamWriter(fileName); Choices myChoices = new Choices(); // Set the myChoice field to a string. Set the // enumType to word. myChoices.myChoice = "Book"; myChoices.enumType = ItemChoiceType.word; // Populate an object array with three items, one // of each enumeration type. Set the array to the // manyChoices field. Object strChoices[] = new Object[] { "Food", (Int32)5, (System.Double)98.6 }; myChoices.manyChoices = strChoices; // For each item in the manyChoices array, add an // enumeration value. int itmChoices[] = new int[] { MoreChoices.item, MoreChoices.amount, MoreChoices.temp }; myChoices.choiceArray = new int[itmChoices.get_Length()]; itmChoices.CopyTo(myChoices.choiceArray, 0); //myChoices.choiceArray = itmChoices; mySerializer.Serialize(writer, myChoices); writer.Close(); } //SerializeObject private void DeserializeObject(String fileName) { XmlSerializer ser = new XmlSerializer(Choices.class.ToType()); // A FileStream is needed to read the XML document. FileStream fs = new FileStream(fileName, FileMode.Open); Choices myChoices = (Choices)ser.Deserialize(fs); fs.Close(); // Disambiguate the myChoice value using the enumeration. if (myChoices.enumType == ItemChoiceType.word) { Console.WriteLine("Word: " + myChoices.myChoice.ToString()); } else { if (myChoices.enumType == ItemChoiceType.number) { Console.WriteLine("Number: " + myChoices.myChoice.ToString()); } else { if (myChoices.enumType == ItemChoiceType.decimalNumber) { Console.WriteLine("DecimalNumber: " + myChoices.myChoice.ToString()); } } } // Disambiguate the manyChoices values using the enumerations. for (int i = 0; i < myChoices.manyChoices.get_Length(); i++) { if (System.Convert.ToInt32(myChoices.choiceArray.get_Item(i)) == MoreChoices.item) { Console.WriteLine("Item: " + (String)(myChoices.manyChoices.get_Item(i))); } else { if (System.Convert.ToInt32(myChoices.choiceArray. get_Item(i)) == MoreChoices.amount) { Console.WriteLine("Amount: " + myChoices.manyChoices.get_Item(i).ToString()); } } if (System.Convert.ToInt32(myChoices.choiceArray. get_Item(i)) == MoreChoices.temp) { Console.WriteLine("Temp: " + (String)( myChoices.manyChoices.get_Item(i).ToString())); } } } //DeserializeObject } //Test

System.Attribute
System.Xml.Serialization.XmlChoiceIdentifierAttribute


Windows 98, Windows 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile for Pocket PC, Windows Mobile for Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
開発プラットフォームの中には、.NET Framework によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


XmlChoiceIdentifierAttribute コンストラクタ ()
アセンブリ: System.Xml (system.xml.dll 内)


MyChoice と ManyChoices という 2 つのフィールドを含んでいる Choices という名前のクラスをシリアル化する例を次に示します。各フィールドに XmlChoiceIdentifierAttribute が適用されており、これらのフィールドは、MemberName プロパティを使用して、それぞれのメンバの値を検出するための列挙体を取得または設定する別のクラス メンバを指定しています。MyChoice フィールドには、対応する列挙体メンバが EnumType フィールド内に存在している単一の値を設定できます。ManyChoices フィールドは、オブジェクトの配列を返します。ChoiceArray フィールドは、列挙値の配列を返します。ManyChoices フィールドの各配列メンバに対応するメンバが、ChoiceArray フィールドによって返される配列の中に見つかります。
Imports System Imports System.Xml Imports System.Xml.Serialization Imports System.IO Public Class Choices ' The MyChoice field can be set to any one of ' the types below. <XmlChoiceIdentifier("EnumType"), _ XmlElement("Word", GetType(String)), _ XmlElement("Number", GetType(Integer)), _ XmlElement("DecimalNumber", GetType(double))> _ Public MyChoice As Object ' Don't serialize this field. The EnumType field ' contains the enumeration value that corresponds ' to the MyChoice field value. <XmlIgnore> _ Public EnumType As ItemChoiceType 'The ManyChoices field can contain an array ' of choices. Each choice must be matched to ' an array item in the ChoiceArray field. <XmlChoiceIdentifier("ChoiceArray"), _ XmlElement("Item", GetType(string)), _ XmlElement("Amount", GetType(Integer)), _ XmlElement("Temp", GetType(double))> _ Public ManyChoices() As Object ' TheChoiceArray field contains the enumeration ' values, one for each item in the ManyChoices array. <XmlIgnore> _ Public ChoiceArray() As MoreChoices End Class <XmlType(IncludeInSchema:=false)> _ Public Enum ItemChoiceType None Word Number DecimalNumber End Enum <XmlType(IncludeInSchema:=false)> _ Public Enum MoreChoices None Item Amount Temp End Enum Public Class Test Shared Sub Main() Dim t As Test = New Test() t.SerializeObject("Choices.xml") t.DeserializeObject("Choices.xml") End Sub private Sub SerializeObject(filename As string) Dim mySerializer As XmlSerializer = _ New XmlSerializer(GetType(Choices)) Dim writer As TextWriter = New StreamWriter(filename) Dim myChoices As Choices = New Choices() ' Set the MyChoice field to a string. Set the ' EnumType to Word. myChoices.MyChoice= "Book" myChoices.EnumType = ItemChoiceType.Word ' Populate an object array with three items, one ' of each enumeration type. Set the array to the ' ManyChoices field. Dim strChoices () As Object = New object(){"Food", 5, 98.6} myChoices.ManyChoices=strChoices ' For each item in the ManyChoices array, add an ' enumeration value. Dim itmChoices () As MoreChoices = New MoreChoices() _ {MoreChoices.Item, _ MoreChoices.Amount, _ MoreChoices.Temp} myChoices.ChoiceArray=itmChoices mySerializer.Serialize(writer, myChoices) writer.Close() End Sub private Sub DeserializeObject(filename As string) Dim ser As XmlSerializer = New XmlSerializer(GetType(Choices)) ' A FileStream is needed to read the XML document. Dim fs As FileStream = New FileStream(filename, FileMode.Open) Dim myChoices As Choices = CType(ser.Deserialize(fs), Choices) fs.Close() ' Disambiguate the MyChoice value Imports the enumeration. if myChoices.EnumType = ItemChoiceType.Word Then Console.WriteLine("Word: " & _ myChoices.MyChoice.ToString()) else if myChoices.EnumType = ItemChoiceType.Number Then Console.WriteLine("Number: " & _ myChoices.MyChoice.ToString()) else if myChoices.EnumType = ItemChoiceType.DecimalNumber Then Console.WriteLine("DecimalNumber: " & _ myChoices.MyChoice.ToString()) End If ' Disambiguate the ManyChoices values Imports the enumerations. Dim i As Integer for i = 0 to myChoices.ManyChoices.Length -1 if myChoices.ChoiceArray(i) = MoreChoices.Item Then Console.WriteLine("Item: " + _ myChoices.ManyChoices(i).ToString()) else if myChoices.ChoiceArray(i) = MoreChoices.Amount Then Console.WriteLine("Amount: " + _ myChoices.ManyChoices(i).ToString()) else if (myChoices.ChoiceArray(i) = MoreChoices.Temp) Console.WriteLine("Temp: " + _ myChoices.ManyChoices(i).ToString()) End If Next i End Sub End Class
using System; using System.Xml; using System.Xml.Serialization; using System.IO; public class Choices{ // The MyChoice field can be set to any one of // the types below. [XmlChoiceIdentifier("EnumType")] [XmlElement("Word", typeof(string))] [XmlElement("Number", typeof(int))] [XmlElement("DecimalNumber", typeof(double))] public object MyChoice; // Don't serialize this field. The EnumType field // contains the enumeration value that corresponds // to the MyChoice field value. [XmlIgnore] public ItemChoiceType EnumType; // The ManyChoices field can contain an array // of choices. Each choice must be matched to // an array item in the ChoiceArray field. [XmlChoiceIdentifier("ChoiceArray")] [XmlElement("Item", typeof(string))] [XmlElement("Amount", typeof(int))] [XmlElement("Temp", typeof(double))] public object[] ManyChoices; // TheChoiceArray field contains the enumeration // values, one for each item in the ManyChoices array. [XmlIgnore] public MoreChoices[] ChoiceArray; } [XmlType(IncludeInSchema=false)] public enum ItemChoiceType{ None, Word, Number, DecimalNumber } public enum MoreChoices{ None, Item, Amount, Temp } public class Test{ static void Main(){ Test t = new Test(); t.SerializeObject("Choices.xml"); t.DeserializeObject("Choices.xml"); } private void SerializeObject(string filename){ XmlSerializer mySerializer = new XmlSerializer(typeof(Choices)); TextWriter writer = new StreamWriter(filename); Choices myChoices = new Choices(); // Set the MyChoice field to a string. Set the // EnumType to Word. myChoices.MyChoice= "Book"; myChoices.EnumType = ItemChoiceType.Word; // Populate an object array with three items, one // of each enumeration type. Set the array to the // ManyChoices field. object[] strChoices = new object[]{"Food", 5, 98.6}; myChoices.ManyChoices=strChoices; // For each item in the ManyChoices array, add an // enumeration value. MoreChoices[] itmChoices = new MoreChoices[] {MoreChoices.Item, MoreChoices.Amount, MoreChoices.Temp}; myChoices.ChoiceArray=itmChoices; mySerializer.Serialize(writer, myChoices); writer.Close(); } private void DeserializeObject(string filename){ XmlSerializer ser = new XmlSerializer(typeof(Choices)); // A FileStream is needed to read the XML document. FileStream fs = new FileStream(filename, FileMode.Open); Choices myChoices = (Choices) ser.Deserialize(fs); fs.Close(); // Disambiguate the MyChoice value using the enumeration. if(myChoices.EnumType == ItemChoiceType.Word){ Console.WriteLine("Word: " + myChoices.MyChoice.ToString()); } else if(myChoices.EnumType == ItemChoiceType.Number){ Console.WriteLine("Number: " + myChoices.MyChoice.ToString()); } else if(myChoices.EnumType == ItemChoiceType.DecimalNumber){ Console.WriteLine("DecimalNumber: " + myChoices.MyChoice.ToString()); } // Disambiguate the ManyChoices values using the enumerations. for(int i = 0; i<myChoices.ManyChoices.Length; i++){ if(myChoices.ChoiceArray[i] == MoreChoices.Item) Console.WriteLine("Item: " + (string) myChoices.ManyChoices[i]); else if(myChoices.ChoiceArray[i] == MoreChoices.Amount) Console.WriteLine("Amount: " + myChoices.ManyChoices[i].ToString()); if(myChoices.ChoiceArray[i] == MoreChoices.Temp) Console.WriteLine("Temp: " + (string) myChoices.ManyChoices[i].ToString()); } } }
#using <System.dll> #using <System.xml.dll> using namespace System; using namespace System::Xml; using namespace System::Xml::Serialization; using namespace System::IO; [XmlType(IncludeInSchema=false)] public enum class ItemChoiceType { None, Word, Number, DecimalNumber }; public enum class MoreChoices { None, Item, Amount, Temp }; public ref class Choices { public: // The MyChoice field can be set to any one of // the types below. [XmlChoiceIdentifier("EnumType")] [XmlElement("Word",String::typeid)] [XmlElement("Number",Int32::typeid)] [XmlElement("DecimalNumber",Double::typeid)] Object^ MyChoice; // Don't serialize this field. The EnumType field // contains the enumeration value that corresponds // to the MyChoice field value. [XmlIgnore] ItemChoiceType EnumType; // The ManyChoices field can contain an array // of choices. Each choice must be matched to // an array item in the ChoiceArray field. [XmlChoiceIdentifier("ChoiceArray")] [XmlElement("Item",String::typeid)] [XmlElement("Amount",Int32::typeid)] [XmlElement("Temp",Double::typeid)] array<Object^>^ManyChoices; // TheChoiceArray field contains the enumeration // values, one for each item in the ManyChoices array. [XmlIgnore] array<MoreChoices>^ChoiceArray; }; void SerializeObject( String^ filename ); void DeserializeObject( String^ filename ); int main() { SerializeObject( "Choices.xml" ); DeserializeObject( "Choices.xml" ); } void SerializeObject( String^ filename ) { XmlSerializer^ mySerializer = gcnew XmlSerializer( Choices::typeid ); TextWriter^ writer = gcnew StreamWriter( filename ); Choices^ myChoices = gcnew Choices; // Set the MyChoice field to a string. Set the // EnumType to Word. myChoices->MyChoice = "Book"; myChoices->EnumType = ItemChoiceType::Word; // Populate an object array with three items, one // of each enumeration type. Set the array to the // ManyChoices field. array<Object^>^strChoices = {"Food",5,98.6}; myChoices->ManyChoices = strChoices; // For each item in the ManyChoices array, add an // enumeration value. array<MoreChoices>^ itmChoices = {MoreChoices::Item,MoreChoices::Amount ,MoreChoices::Temp}; myChoices->ChoiceArray = itmChoices; mySerializer->Serialize( writer, myChoices ); writer->Close(); } void DeserializeObject( String^ filename ) { XmlSerializer^ ser = gcnew XmlSerializer( Choices::typeid ); // A FileStream is needed to read the XML document. FileStream^ fs = gcnew FileStream( filename,FileMode::Open ); Choices^ myChoices = safe_cast<Choices^>(ser->Deserialize( fs )); fs->Close(); // Disambiguate the MyChoice value using the enumeration. if ( myChoices->EnumType == ItemChoiceType::Word ) { Console::WriteLine( "Word: {0}", myChoices->MyChoice->ToString() ); } else if ( myChoices->EnumType == ItemChoiceType::Number ) { Console::WriteLine( "Number: {0}", myChoices->MyChoice->ToString() ); } else if ( myChoices->EnumType == ItemChoiceType::DecimalNumber ) { Console::WriteLine( "DecimalNumber: {0}", myChoices->MyChoice->ToString() ); } // Disambiguate the ManyChoices values using the enumerations. for ( int i = 0; i < myChoices->ManyChoices->Length; i++ ) { if ( myChoices->ChoiceArray[ i ] == MoreChoices::Item ) Console::WriteLine( "Item: {0}", myChoices->ManyChoices[ i ] ); else if ( myChoices->ChoiceArray[ i ] == MoreChoices::Amount ) Console::WriteLine( "Amount: ", myChoices->ManyChoices[ i ]->ToString() ); if ( myChoices->ChoiceArray[ i ] == MoreChoices::Temp ) Console::WriteLine( "Temp: {0}", myChoices->ManyChoices[ i ]->ToString() ); } }
import System.*; import System.Xml.*; import System.Xml.Serialization.*; import System.IO.*; public class Choices { // The myChoice field can be set to any one of // the types below. /** @attribute XmlElement("word", String.class) */ /** @attribute XmlElement("Number", int.class) */ /** @attribute XmlElement("DecimalNumber", double.class) */ public Object myChoice; // Don't serialize this field. The EnumType field // contains the enumeration value that corresponds // to the myChoice field value. public int enumType; // The manyChoices field can contain an array // of choices. Each choice must be matched to // an array item in the choiceArray field. /** @attribute XmlElement("Item", String.class) */ /** @attribute XmlElement("amount", int.class) */ /** @attribute XmlElement("temp", double.class) */ public Object manyChoices[]; // ThechoiceArray field contains the enumeration // values, one for each item in the manyChoices array. public int choiceArray[]; } //Choices /** @attribute XmlType(IncludeInSchema = false) */ public class ItemChoiceType { public static final int none = 0; public static final int word = 1; public static final int number = 2; public static final int decimalNumber = 3; } //ItemChoiceType public class MoreChoices { public static final int none = 0; public static final int item = 1; public static final int amount = 2; public static final int temp = 3; } //MoreChoices public class Test { public static void main(String[] args) { Test t = new Test(); t.SerializeObject("Choices.xml"); t.DeserializeObject("Choices.xml"); } //main private void SerializeObject(String fileName) { XmlSerializer mySerializer = new XmlSerializer(Choices.class.ToType()); TextWriter writer = new StreamWriter(fileName); Choices myChoices = new Choices(); // Set the myChoice field to a string. Set the // enumType to word. myChoices.myChoice = "Book"; myChoices.enumType = ItemChoiceType.word; // Populate an object array with three items, one // of each enumeration type. Set the array to the // manyChoices field. Object strChoices[] = new Object[] { "Food", (Int32)5, (System.Double)98.6 }; myChoices.manyChoices = strChoices; // For each item in the manyChoices array, add an // enumeration value. int itmChoices[] = new int[] { MoreChoices.item, MoreChoices.amount, MoreChoices.temp }; myChoices.choiceArray = new int[itmChoices.get_Length()]; itmChoices.CopyTo(myChoices.choiceArray, 0); //myChoices.choiceArray = itmChoices; mySerializer.Serialize(writer, myChoices); writer.Close(); } //SerializeObject private void DeserializeObject(String fileName) { XmlSerializer ser = new XmlSerializer(Choices.class.ToType()); // A FileStream is needed to read the XML document. FileStream fs = new FileStream(fileName, FileMode.Open); Choices myChoices = (Choices)ser.Deserialize(fs); fs.Close(); // Disambiguate the myChoice value using the enumeration. if (myChoices.enumType == ItemChoiceType.word) { Console.WriteLine("Word: " + myChoices.myChoice.ToString()); } else { if (myChoices.enumType == ItemChoiceType.number) { Console.WriteLine("Number: " + myChoices.myChoice.ToString()); } else { if (myChoices.enumType == ItemChoiceType.decimalNumber) { Console.WriteLine("DecimalNumber: " + myChoices.myChoice.ToString()); } } } // Disambiguate the manyChoices values using the enumerations. for (int i = 0; i < myChoices.manyChoices.get_Length(); i++) { if (System.Convert.ToInt32(myChoices.choiceArray.get_Item(i)) == MoreChoices.item) { Console.WriteLine("Item: " + (String)(myChoices.manyChoices.get_Item(i))); } else { if (System.Convert.ToInt32(myChoices.choiceArray. get_Item(i)) == MoreChoices.amount) { Console.WriteLine("Amount: " + myChoices.manyChoices.get_Item(i).ToString()); } } if (System.Convert.ToInt32(myChoices.choiceArray. get_Item(i)) == MoreChoices.temp) { Console.WriteLine("Temp: " + (String)( myChoices.manyChoices.get_Item(i).ToString())); } } } //DeserializeObject } //Test

Windows 98, Windows 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile for Pocket PC, Windows Mobile for Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
開発プラットフォームの中には、.NET Framework によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


XmlChoiceIdentifierAttribute コンストラクタ (String)
アセンブリ: System.Xml (system.xml.dll 内)


Windows 98, Windows 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile for Pocket PC, Windows Mobile for Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
開発プラットフォームの中には、.NET Framework によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


XmlChoiceIdentifierAttribute コンストラクタ

名前 | 説明 |
---|---|
XmlChoiceIdentifierAttribute () | XmlChoiceIdentifierAttribute クラスの新しいインスタンスを初期化します。 .NET Compact Framework によってサポートされています。 |
XmlChoiceIdentifierAttribute (String) | XmlChoiceIdentifierAttribute クラスの新しいインスタンスを初期化します。 .NET Compact Framework によってサポートされています。 |

XmlChoiceIdentifierAttribute プロパティ
XmlChoiceIdentifierAttribute メソッド

名前 | 説明 | |
---|---|---|
![]() | Equals | オーバーロードされます。 ( Attribute から継承されます。) |
![]() | GetCustomAttribute | オーバーロードされます。 アセンブリ、モジュール、型のメンバ、またはメソッド パラメータに適用された指定した型のカスタム属性を取得します。 ( Attribute から継承されます。) |
![]() | GetCustomAttributes | オーバーロードされます。 アセンブリ、モジュール、型のメンバ、またはメソッド パラメータに適用されたカスタム属性の配列を取得します。 ( Attribute から継承されます。) |
![]() | GetHashCode | このインスタンスのハッシュ コードを返します。 ( Attribute から継承されます。) |
![]() | GetType | 現在のインスタンスの Type を取得します。 ( Object から継承されます。) |
![]() | IsDefaultAttribute | 派生クラス内でオーバーライドされたときに、このインスタンスの値が派生クラスの既定値かどうかを示します。 ( Attribute から継承されます。) |
![]() | IsDefined | オーバーロードされます。 指定した型のカスタム属性が、アセンブリ、モジュール、型のメンバ、またはメソッド パラメータに適用されているかどうかを判断します。 ( Attribute から継承されます。) |
![]() | Match | 派生クラス内でオーバーライドされたときに、指定したオブジェクトとこのインスタンスが等しいかどうかを示す値を返します。 ( Attribute から継承されます。) |
![]() | ReferenceEquals | 指定した複数の Object インスタンスが同一かどうかを判断します。 ( Object から継承されます。) |
![]() | ToString | 現在の Object を表す String を返します。 ( Object から継承されます。) |

名前 | 説明 | |
---|---|---|
![]() | Finalize | Object がガベージ コレクションにより収集される前に、その Object がリソースを解放し、その他のクリーンアップ操作を実行できるようにします。 ( Object から継承されます。) |
![]() | MemberwiseClone | 現在の Object の簡易コピーを作成します。 ( Object から継承されます。) |

XmlChoiceIdentifierAttribute メンバ
列挙体を使用して、メンバを明確に検出できるようにすることを指定します。
XmlChoiceIdentifierAttribute データ型で公開されるメンバを以下の表に示します。



名前 | 説明 | |
---|---|---|
![]() | Equals | オーバーロードされます。 ( Attribute から継承されます。) |
![]() | GetCustomAttribute | オーバーロードされます。 アセンブリ、モジュール、型のメンバ、またはメソッド パラメータに適用された指定した型のカスタム属性を取得します。 (Attribute から継承されます。) |
![]() | GetCustomAttributes | オーバーロードされます。 アセンブリ、モジュール、型のメンバ、またはメソッド パラメータに適用されたカスタム属性の配列を取得します。 (Attribute から継承されます。) |
![]() | GetHashCode | このインスタンスのハッシュ コードを返します。 (Attribute から継承されます。) |
![]() | GetType | 現在のインスタンスの Type を取得します。 (Object から継承されます。) |
![]() | IsDefaultAttribute | 派生クラス内でオーバーライドされたときに、このインスタンスの値が派生クラスの既定値かどうかを示します。 (Attribute から継承されます。) |
![]() | IsDefined | オーバーロードされます。 指定した型のカスタム属性が、アセンブリ、モジュール、型のメンバ、またはメソッド パラメータに適用されているかどうかを判断します。 (Attribute から継承されます。) |
![]() | Match | 派生クラス内でオーバーライドされたときに、指定したオブジェクトとこのインスタンスが等しいかどうかを示す値を返します。 (Attribute から継承されます。) |
![]() | ReferenceEquals | 指定した複数の Object インスタンスが同一かどうかを判断します。 (Object から継承されます。) |
![]() | ToString | 現在の Object を表す String を返します。 (Object から継承されます。) |

名前 | 説明 | |
---|---|---|
![]() | Finalize | Object がガベージ コレクションにより収集される前に、その Object がリソースを解放し、その他のクリーンアップ操作を実行できるようにします。 (Object から継承されます。) |
![]() | MemberwiseClone | 現在の Object の簡易コピーを作成します。 (Object から継承されます。) |

Weblioに収録されているすべての辞書からXmlChoiceIdentifierAttributeを検索する場合は、下記のリンクをクリックしてください。

- XmlChoiceIdentifierAttributeのページへのリンク