執行階段指示詞 (rd.xml) 組態檔參考

執行階段指示詞 (.rd.xml) 檔案是 XML 組態檔,指定所委任的程式元素是否適用於反映。 如需如何將執行階段指示詞新增至專案以及如何辨識執行階段指示詞的資訊,請參閱 MissingMetadataException 疑難排解工具

以下是執行階段指示詞檔案的範例:

<Directives xmlns="http://schemas.microsoft.com/netfx/2013/01/metadata">
  <Application>
    <Namespace Name="Contoso.Cloud.AppServices" Serialize="Required Public" />
    <Namespace Name="ContosoClient.ViewModels" Serialize="Required Public" />
    <Namespace Name="ContosoClient.DataModel" Serialize="Required Public" />
    <Namespace Name="Contoso.Reader.UtilityLib" Serialize="Required Public" />

    <Namespace Name="System.Collections.ObjectModel" >
      <TypeInstantiation Name="ObservableCollection"
            Arguments="ContosoClient.DataModel.ProductItem" Serialize="Public" />
      <TypeInstantiation Name="ReadOnlyObservableCollection"
            Arguments="ContosoClient.DataModel.ProductGroup" Serialize="Public" />
    </Namespace>
  </Application>
</Directives>

執行階段指示詞檔案的結構

執行階段指示詞檔案使用 http://schemas.microsoft.com/netfx/2013/01/metadata 命名空間。

根項目是 Directives 項目。 它可以包含零 (含) 個以上的 Library 項目,以及零或一個的 Application 項目,如下列結構所示。 Application 項目的屬性可以定義整個應用程式的執行階段反映原則,或是作為子項目的容器。 另一方面,Library 項目只是容器。 ApplicationLibrary 項目的子項可定義適用於反映的類型、方法、欄位、屬性和事件。

如需參考資訊,請從下列結構中選擇項目,或參閱執行階段指示詞項目。 在下列階層中,省略符號標記了遞迴結構。 方括號中的資訊指出該元素是選用或必要元素,以及如果使用該元素,可允許多少執行個體 (一個或多個)。

Application 項目可以沒有任何屬性,或者可以有執行階段指示詞和原則一節中所描述的原則屬性。

Library 項目具有單一屬性 Name,可指定程式庫或組件的名稱,但不含副檔名。 例如,下列 Library 項目套用於名為 Extensions.dll 的組件。

<Directives xmlns="http://schemas.microsoft.com/netfx/2013/01/metadata">
  <Application>
     <!-- Child elements go here -->
  </Application>
  <Library Name="Extensions">
     <!-- Child elements go here -->
  </Library>
</Directives>

執行階段指示詞和原則

Application 項目本身以及 LibraryApplication 項目的子項目表示原則;也就是說,其定義應用程式可以將反映套用於程式項目的方式。 原則類型是由元素的屬性 (例如 Serialize) 來定義。 原則值是由屬性的值 (例如 Serialize="Required") 來定義。

項目屬性所指定的任何原則,都會套用至沒有為該原則指定值的所有子項目。 例如,如果以 Type 項目來指定原則,則該原則會套用至未明確指定原則的所有內含類型和成員。

可以使用 ApplicationAssemblyAttributeImpliesNamespaceSubtypesType 項目表示的原則,不同於可以為個別成員表示的原則 (使用 MethodPropertyFieldEvent 項目)。

為組件、命名空間和類型指定原則

ApplicationAssemblyAttributeImpliesNamespaceSubtypesType 項目支援下列原則類型:

  • Activate. 控制建構函式的執行階段存取,以便啟動執行個體。

  • Browse. 控制程式項目相關資訊的查詢,但不會啟用任何執行階段存取。

  • Dynamic. 控制對所有類型成員 (包括建構函式、方法、欄位、屬性和事件) 的執行階段存取,以啟用動態程式設計。

  • Serialize. 控制對建構函式、欄位和屬性的執行階段存取,讓類型執行個體能夠以 Newtonsoft JSON 序列化程式之類的協力廠商程式庫來序列化和還原序列化。

  • DataContractSerializer. 控制使用 System.Runtime.Serialization.DataContractSerializer 類別的序列化原則。

  • DataContractJsonSerializer. 控制使用 System.Runtime.Serialization.DataContractSerializer 類別的 JSON 序列化原則。

  • XmlSerializer. 控制使用 System.Xml.Serialization.XmlSerializer 類別的 XML 序列化原則。

  • MarshalObject. 控制將參考類型封送處理至 WinRT 及 COM 的原則。

  • MarshalDelegate. 控制將委派類型當作函式指標封送處理至機器碼的原則。

  • MarshalStructure . 控制將結構封送處理至機器碼的原則。

與這些原則類型相關聯的設定如下:

  • All. 針對工具鏈未移除的所有類型和成員,啟用原則。

  • Auto. 使用預設行為。 (除非原則被 (例如父元素) 覆寫,否則,不指定原則相當於將該原則設定為 Auto。)

  • Excluded. 為程式元素停用原則。

  • Public. 為公用類型或成員啟用原則,除非工具鏈判斷該成員是不必要的,並因此將它移除。 (在後者的情況下,您必須使用 Required Public 以確保該成員會保留,而且具有反映功能。)

  • PublicAndInternal. 如果公用和內部類型或成員沒有被工具鏈移除,則為其啟用原則。

  • Required Public. 需要工具鏈保留公用類型和成員 (無論是否使用),並為其啟用原則。

  • Required PublicAndInternal. 需要工具鏈同時保留公用和內部類型和成員 (無論是否使用),並為其啟用原則。

  • Required All. 需要工具鏈保留所有類型和成員 (無論是否使用),並為其啟用原則。

例如,下列執行階段指示詞檔案會為組件 DataClasses.dll 中的所有類型和成員定義原則。 它會為所有公用屬性 (property) 的序列化啟用反映功能,為所有類型和類型成員啟用瀏覽功能,為所有類型啟用啟動功能 (因為 Dynamic 屬性 (attribute)),並為所有公用類型和成員啟用反映功能。

<Directives xmlns="http://schemas.microsoft.com/netfx/2013/01/metadata">
   <Application>
      <Assembly Name="DataClasses" Serialize="Required Public"
                Browse="All" Activate="PublicAndInternal"
                Dynamic="Public"  />
   </Application>
   <Library Name="UtilityLibrary">
     <!-- Child elements go here -->
   </Library>
</Directives>

為成員指定原則

PropertyField 項目支援下列原則類型:

  • Browse - 控制對此成員相關資訊的查詢,但不會啟用任何執行階段存取。

  • Dynamic - 控制對所有類型成員 (包括建構函式、方法、欄位、屬性和事件) 的執行階段存取,以啟用動態程式設計。 另外也會控制對包含類型相關資訊的查詢。

  • Serialize - 控制對成員的執行階段存取,讓類型執行個體能夠以 Newtonsoft JSON 序列化程式之類的程式庫來序列化和還原序列化。 這個原則可以套用至建構函式、欄位和屬性。

MethodEvent 項目支援下列原則類型:

  • Browse - 控制對此成員相關資訊的查詢,但不會啟用任何執行階段存取。

  • Dynamic - 控制對所有類型成員 (包括建構函式、方法、欄位、屬性和事件) 的執行階段存取,以啟用動態程式設計。 另外也會控制對包含類型相關資訊的查詢。

與這些原則類型相關聯的設定如下:

  • Auto - 使用預設行為。 (除非原則被覆寫,否則,不指定原則相當於將該原則設定為 Auto。)

  • Excluded - 永不包含成員的中繼資料。

  • Included - 如果父類型出現在輸出中,則啟用原則。

  • Required - 需要工具鏈保留此成員 (即使看似未使用),並為其啟用原則。

執行階段指示詞檔案語意

可以將原則同時定義給較高層級和較低層級的元素。 例如,可以將原則定義給組件,以及該組件內含的一些類型。 如果未表示特定較低層級的元素,它會繼承其父元素的原則。 例如,如果 Assembly 元素存在,但 Type 元素不存在,則 Assembly 元素中指定的原則會套用至組件中的每個類型。 多個元素也可以將原則套用至相同的程式元素。 例如,個別的 Assembly 項目可能會以不同的方式,為相同的組件定義相同的原則項目。 以下章節將說明在這些情況下,如何解析特定類型的原則。

泛型型別或方法的 TypeMethod 項目,會將其原則套用至沒有自己原則的所有具現化。 例如,為 Type 指定原則的 List<T> 元素,會套用至該泛型類型的所有建構執行個體,除非已針對特定的建構泛型類型 (例如 List<Int32>),以 TypeInstantiation 元素將它覆寫, 否則,元素會為所指名的程式元素定義原則。

當元素模稜兩可時,引擎會尋找相符項目,如果找到完全相符的項目,就會使用它。 如果找到多個相符項目,則會產生警告或錯誤。

如果有兩個指示詞將原則套用至相同的程式元素

如果不同執行階段指示詞檔案中的兩個元素,嘗試將相同程式元素 (例如組件或類型) 的相同原則類型設定為不同的值,則會以下列方式解決衝突:

  1. 如果 Excluded 元素存在,則以它為優先。

  2. Required 的優先順序高於非 Required

  3. All 的優先順序高於 PublicAndInternal,而後者的優先順序高於 Public

  4. 任何明確的設定皆優先於 Auto

例如,如果單一專案包含下列兩個執行階段指示詞檔案,則 DataClasses.dll 的序列化原則會同時設為 Required PublicAll。 在此情況下,序列化原則會被解析成 Required All

<Directives xmlns="http://schemas.microsoft.com/netfx/2013/01/metadata">
   <Application>
      <Assembly Name="DataClasses" Serialize="Required Public"/>
   </Application>
   <Library Name="DataClasses">
      <!-- any other elements -->
   </Library>
</Directives>
<Directives xmlns="http://schemas.microsoft.com/netfx/2013/01/metadata">
   <Application>
      <Assembly Name="DataClasses" Serialize="All" />
   </Application>
   <Library Name="DataClasses">
      <!-- any other elements -->
   </Library>
</Directives>

不過,如果單一執行階段指示詞檔案中的兩個指示詞嘗試為相同的程式元素設定相同的原則類型,則 XML 配置定義工具會顯示錯誤訊息。

如果子元素和父元素套用相同的原則類型

子元素會覆寫其父元素,包括 Excluded 設定。 覆寫是您會想要指定 Auto 的主要原因。

在下列範例中,針對 DataClasses 中不在 DataClasses.ViewModels 內的所有項目,序列化原則設定為 Required Public,而針對不在 DataClassesDataClasses.ViewModels 內的所有項目,則為 All

<Directives xmlns="http://schemas.microsoft.com/netfx/2013/01/metadata">
   <Application>
      <Assembly Name="DataClasses" Serialize="Required Public" >
         <Namespace Name="DataClasses.ViewModels" Serialize="All" />
      </Assembly>
   </Application>
   <Library Name="DataClasses">
      <!-- any other elements -->
   </Library>
</Directives>

如果開放式泛型和具現化的元素套用相同的原則類型

在下列範例中,當引擎有必須為 Dictionary<int,int> 指定 Browse 原則的其他理由時,才會為其指派 Browse 原則 (否則為預設行為);Dictionary<TKey,TValue> 的每個其他具現化都會使其所有成員可供瀏覽。

<Directives xmlns="http://schemas.microsoft.com/netfx/2013/01/metadata">
   <Application>
      <Assembly Name="DataClasses" Serialize="Required Public" >
         <Namespace Name="DataClasses.ViewModels" Serialize="All" />
      </Assembly>
      <Namespace Name="DataClasses.Generics" />
      <Type Name="Dictionary" Browse="All" />
      <TypeInstantiation Name="Dictionary"
                         Arguments="System.Int32,System.Int32" Browse="Auto" />
   </Application>
   <Library Name="DataClasses">
      <!-- any other elements -->
   </Library>
</Directives>

推斷原則的方式

每個原則類型都有一組不同的規則,用以判斷該原則類型的存在對其他建構有何影響。

瀏覽原則的效果

Browse 原則套用至類型牽涉到下列原則變更:

  • 類型的基底類型會標示 Browse 原則。

  • 如果類型是具現化泛型,則該類型的未具現化版本會標示 Browse 原則。

  • 如果類型是委派,則該類型上的 Invoke 方法會標示 Dynamic 原則。

  • 類型的每個介面都會標示 Browse 原則。

  • 套用至類型的每個屬性類型都會標示 Browse 原則。

  • 如果類型是泛型,則每個條件約束類型都會標示 Browse 原則。

  • 如果類型是泛型,則具現化類型之下的類型會標示 Browse 原則。

Browse 原則套用至方法牽涉到下列原則變更:

  • 方法的每個參數類型會標示 Browse 原則。

  • 方法的傳回型別會標示 Browse 原則。

  • 方法的包含類型會標示 Browse 原則。

  • 如果方法是具現化泛型方法,則未具現化的泛型方法會標示 Browse 原則。

  • 套用至方法的每個屬性類型都會標示 Browse 原則。

  • 如果方法是泛型,則每個條件約束類型都會標示 Browse 原則。

  • 如果方法是泛型,則具現化方法之下的類型會標示 Browse 原則。

Browse 原則套用至欄位牽涉到下列原則變更:

  • 套用至欄位的每個屬性類型都會標示 Browse 原則。

  • 欄位的類型會標示 Browse 原則。

  • 欄位所屬的類型會標示 Browse 原則。

動態原則的效果

Dynamic 原則套用至類型牽涉到下列原則變更:

  • 類型的基底類型會標示 Dynamic 原則。

  • 如果類型是具現化泛型,則該類型的未具現化版本會標示 Dynamic 原則。

  • 如果類型是委派類型,則該類型上的 Invoke 方法會標示 Dynamic 原則。

  • 類型的每個介面都會標示 Browse 原則。

  • 套用至類型的每個屬性類型都會標示 Browse 原則。

  • 如果類型是泛型,則每個條件約束類型都會標示 Browse 原則。

  • 如果類型是泛型,則具現化類型之下的類型會標示 Browse 原則。

Dynamic 原則套用至方法牽涉到下列原則變更:

  • 方法的每個參數類型會標示 Browse 原則。

  • 方法的傳回型別會標示 Dynamic 原則。

  • 方法的包含類型會標示 Dynamic 原則。

  • 如果方法是具現化泛型方法,則未具現化的泛型方法會標示 Browse 原則。

  • 套用至方法的每個屬性類型都會標示 Browse 原則。

  • 如果方法是泛型,則每個條件約束類型都會標示 Browse 原則。

  • 如果方法是泛型,則具現化方法之下的類型會標示 Browse 原則。

  • 可以藉由 MethodInfo.Invoke 來叫用方法,而藉由 MethodInfo.CreateDelegate 就能夠進行委派建立。

Dynamic 原則套用至欄位牽涉到下列原則變更:

  • 套用至欄位的每個屬性類型都會標示 Browse 原則。

  • 欄位的類型會標示 Dynamic 原則。

  • 欄位所屬的類型會標示 Dynamic 原則。

啟動原則的效果

將啟動原則套用至類型牽涉到下列原則變更:

  • 如果類型是具現化泛型,則該類型的未具現化版本會標示 Browse 原則。

  • 如果類型是委派類型,則該類型上的 Invoke 方法會標示 Dynamic 原則。

  • 類型的建構函式會標示 Activation 原則。

Activation 原則套用至方法牽涉到下列原則變更:

Activation 原則套用至欄位並沒有效果。

序列化原則的效果

Serialize 原則可以啟用一般反映型序列化程式。 不過,由於 Microsoft 並不清楚非 Microsoft 序列化程式的確切反映存取模式,所以此原則可能不是全面有效。

Serialize 原則套用至類型牽涉到下列原則變更:

  • 類型的基底類型會標示 Serialize 原則。

  • 如果類型是具現化泛型,則該類型的未具現化版本會標示 Browse 原則。

  • 如果類型是委派類型,則該類型上的 Invoke 方法會標示 Dynamic 原則。

  • 如果類型是列舉,則類型的陣列會標示 Serialize 原則。

  • 如果類型實作 IEnumerable<T>,則 T 會標示 Serialize 原則。

  • 如果類型是 IEnumerable<T>IList<T>ICollection<T>IReadOnlyCollection<T>IReadOnlyList<T>,則 T[]List<T> 會標示 Serialize 原則,但介面類型沒有任何成員會標示 Serialize 原則。

  • 如果類型是 List<T>,則沒有任何類型成員會標示 Serialize 原則。

  • 如果類型是 IDictionary<TKey,TValue>,則 Dictionary<TKey,TValue> 會標示 Serialize 原則, 但沒有任何類型成員會標示 Serialize 原則。

  • 如果類型是 Dictionary<TKey,TValue>,則沒有任何類型成員會標示 Serialize 原則。

  • 如果類型實作 IDictionary<TKey,TValue>,則 TKeyTValue 會標示 Serialize 原則。

  • 每個建構函式、每個屬性存取子和每個欄位都會標示 Serialize 原則。

Serialize 原則套用至方法牽涉到下列原則變更:

  • 包含類型會標示 Serialize 原則。

  • 方法的傳回型別會標示 Serialize 原則。

Serialize 原則套用至欄位牽涉到下列原則變更:

  • 包含類型會標示 Serialize 原則。

  • 欄位的類型會標示 Serialize 原則。

XmlSerializer、DataContractSerializer 和 DataContractJsonSerializer 原則的效果

不像 Serialize 原則是主要用於反映型序列化程式,XmlSerializerDataContractSerializerDataContractJsonSerializer 原則是要用來啟用 .NET Native 工具鏈已知的序列化程式集。 這些序列化程式不是使用反映來實作,但是可以用類似可反映式類型的方法,來判斷可以在執行階段序列化的類型集。

將這些原則的其中之一套用至類型,可讓該類型以相符的序列化程式來進行序列化。 此外,序列化引擎可以用靜態方式判斷為需要序列化的任何類型,也都可以序列化。

這些原則對方法或欄位沒有任何效果。

如需詳細資訊,請參閱將您的 Windows 市集應用程式移轉至 .NET Native中的<序列化程式的差異>一節。

另請參閱