AssemblyName 類別

定義

完整描述組件的唯一識別。

public sealed class AssemblyName
public sealed class AssemblyName : ICloneable, System.Runtime.Serialization.IDeserializationCallback, System.Runtime.Serialization.ISerializable
[System.Runtime.InteropServices.ClassInterface(System.Runtime.InteropServices.ClassInterfaceType.None)]
[System.Serializable]
public sealed class AssemblyName : ICloneable, System.Runtime.InteropServices._AssemblyName, System.Runtime.Serialization.IDeserializationCallback, System.Runtime.Serialization.ISerializable
[System.Runtime.InteropServices.ClassInterface(System.Runtime.InteropServices.ClassInterfaceType.None)]
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public sealed class AssemblyName : ICloneable, System.Runtime.InteropServices._AssemblyName, System.Runtime.Serialization.IDeserializationCallback, System.Runtime.Serialization.ISerializable
繼承
AssemblyName
屬性
實作

範例

此範例示範如何使用各種反映類別來分析元件中包含的元數據。

using System;
using System.Reflection;

class Module1
{
    public static void Main()
    {
        // This variable holds the amount of indenting that
        // should be used when displaying each line of information.
        Int32 indent = 0;
        // Display information about the EXE assembly.
        Assembly a = typeof(Module1).Assembly;
        Display(indent, "Assembly identity={0}", a.FullName);
        Display(indent+1, "Codebase={0}", a.CodeBase);

        // Display the set of assemblies our assemblies reference.

        Display(indent, "Referenced assemblies:");
        foreach (AssemblyName an in a.GetReferencedAssemblies() )
        {
             Display(indent + 1, "Name={0}, Version={1}, Culture={2}, PublicKey token={3}", an.Name, an.Version, an.CultureInfo.Name, (BitConverter.ToString (an.GetPublicKeyToken())));
        }
        Display(indent, "");

        // Display information about each assembly loading into this AppDomain.
        foreach (Assembly b in AppDomain.CurrentDomain.GetAssemblies())
        {
            Display(indent, "Assembly: {0}", b);

            // Display information about each module of this assembly.
            foreach ( Module m in b.GetModules(true) )
            {
                Display(indent+1, "Module: {0}", m.Name);
            }

            // Display information about each type exported from this assembly.

            indent += 1;
            foreach ( Type t in b.GetExportedTypes() )
            {
                Display(0, "");
                Display(indent, "Type: {0}", t);

                // For each type, show its members & their custom attributes.

                indent += 1;
                foreach (MemberInfo mi in t.GetMembers() )
                {
                    Display(indent, "Member: {0}", mi.Name);
                    DisplayAttributes(indent, mi);

                    // If the member is a method, display information about its parameters.

                    if (mi.MemberType==MemberTypes.Method)
                    {
                        foreach ( ParameterInfo pi in ((MethodInfo) mi).GetParameters() )
                        {
                            Display(indent+1, "Parameter: Type={0}, Name={1}", pi.ParameterType, pi.Name);
                        }
                    }

                    // If the member is a property, display information about the property's accessor methods.
                    if (mi.MemberType==MemberTypes.Property)
                    {
                        foreach ( MethodInfo am in ((PropertyInfo) mi).GetAccessors() )
                        {
                            Display(indent+1, "Accessor method: {0}", am);
                        }
                    }
                }
                indent -= 1;
            }
            indent -= 1;
        }
    }

    // Displays the custom attributes applied to the specified member.
    public static void DisplayAttributes(Int32 indent, MemberInfo mi)
    {
        // Get the set of custom attributes; if none exist, just return.
        object[] attrs = mi.GetCustomAttributes(false);
        if (attrs.Length==0) {return;}

        // Display the custom attributes applied to this member.
        Display(indent+1, "Attributes:");
        foreach ( object o in attrs )
        {
            Display(indent+2, "{0}", o.ToString());
        }
    }

    // Display a formatted string indented by the specified amount.
    public static void Display(Int32 indent, string format, params object[] param)

    {
        Console.Write(new string(' ', indent*2));
        Console.WriteLine(format, param);
    }
}

//The output shown below is abbreviated.
//
//Assembly identity=ReflectionCS, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
//  Codebase=file:///C:/Documents and Settings/test/My Documents/Visual Studio 2005/Projects/Reflection/Reflection/obj/Debug/Reflection.exe
//Referenced assemblies:
//  Name=mscorlib, Version=2.0.0.0, Culture=, PublicKey token=B7-7A-5C-56-19-34-E0-89
//
//Assembly: mscorlib, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
//  Module: mscorlib.dll
//  Module: mscorlib.dll
//  Module: mscorlib.dll
//  Module: mscorlib.dll
//  Module: mscorlib.dll
//  Module: mscorlib.dll
//  Module: mscorlib.dll
//  Module: mscorlib.dll
//  Module: mscorlib.dll
//  Module: mscorlib.dll
//  Module: mscorlib.dll
//  Module: mscorlib.dll
//  Module: mscorlib.dll
//  Module: mscorlib.dll
//
//  Type: System.Object
//    Member: GetType
//    Member: ToString
//    Member: Equals
//      Parameter: Type=System.Object, Name=obj
//    Member: Equals
//      Parameter: Type=System.Object, Name=objA
//      Parameter: Type=System.Object, Name=objB
//    Member: ReferenceEquals
//      Attributes:
//        System.Runtime.ConstrainedExecution.ReliabilityContractAttribute
//      Parameter: Type=System.Object, Name=objA
//      Parameter: Type=System.Object, Name=objB
//    Member: GetHashCode
//    Member: .ctor
//      Attributes:
//        System.Runtime.ConstrainedExecution.ReliabilityContractAttribute
//
//  Type: System.ICloneable
//    Member: Clone
//
//  Type: System.Collections.IEnumerable
//    Member: GetEnumerator
//      Attributes:
//        System.Runtime.InteropServices.DispIdAttribute
//
//  Type: System.Collections.ICollection
//    Member: CopyTo
//      Parameter: Type=System.Array, Name=array
//      Parameter: Type=System.Int32, Name=index
//    Member: get_Count
//    Member: get_SyncRoot
//    Member: get_IsSynchronized
//    Member: Count
//      Accessor method: Int32 get_Count()
//    Member: SyncRoot
//      Accessor method: System.Object get_SyncRoot()
//    Member: IsSynchronized
//      Accessor method: Boolean get_IsSynchronized()
//
//  Type: System.Collections.IList
//    Member: get_Item
//      Parameter: Type=System.Int32, Name=index
//    Member: set_Item
//      Parameter: Type=System.Int32, Name=index
//      Parameter: Type=System.Object, Name=value
//    Member: Add
//      Parameter: Type=System.Object, Name=value
//    Member: Contains
//      Parameter: Type=System.Object, Name=value
//    Member: Clear
//    Member: get_IsReadOnly
//    Member: get_IsFixedSize
//    Member: IndexOf
//      Parameter: Type=System.Object, Name=value
//    Member: Insert
//      Parameter: Type=System.Int32, Name=index
//      Parameter: Type=System.Object, Name=value
//    Member: Remove
//      Parameter: Type=System.Object, Name=value
//    Member: RemoveAt
//      Parameter: Type=System.Int32, Name=index
//    Member: Item
//      Accessor method: System.Object get_Item(Int32)
//      Accessor method: Void set_Item(Int32, System.Object)
//    Member: IsReadOnly
//      Accessor method: Boolean get_IsReadOnly()
//    Member: IsFixedSize
//      Accessor method: Boolean get_IsFixedSize()
//
//  Type: System.Array
//    Member: IndexOf
//      Parameter: Type=T[], Name=array
//      Parameter: Type=T, Name=value
//    Member: AsReadOnly
//      Parameter: Type=T[], Name=array
//    Member: Resize
//      Attributes:
//        System.Runtime.ConstrainedExecution.ReliabilityContractAttribute
//      Parameter: Type=T[]&, Name=array
//      Parameter: Type=System.Int32, Name=newSize
//    Member: BinarySearch
//      Attributes:
//        System.Runtime.ConstrainedExecution.ReliabilityContractAttribute
//      Parameter: Type=T[], Name=array
//      Parameter: Type=T, Name=value
//    Member: BinarySearch
//      Attributes:
//        System.Runtime.ConstrainedExecution.ReliabilityContractAttribute
//      Parameter: Type=T[], Name=array
//      Parameter: Type=T, Name=value
//      Parameter: Type=System.Collections.Generic.IComparer`1[T], Name=comparer

備註

AssemblyName物件包含元件的相關信息,可用來系結至該元件。 元件的身分識別包含下列各項:

  • 簡單名稱。

  • 版本號碼。

  • 密碼編譯金鑰組。

  • 支援的文化特性。

簡單名稱通常是指令清單檔的檔名,沒有擴展名。 密鑰組包含公用和私鑰,用來建立元件的強名稱簽章。

所有支援 Common Language Runtime 的編譯程式都會發出巢狀類別的簡單名稱,而反映會根據下列慣例在查詢時建構管理的名稱。

分隔符號 意義
反斜線 (\) 逸出字元。
逗號 (,) 元件名稱之前。
加號 (+) 在巢狀類別之前。

例如,類別的完整名稱可能如下所示:

IncludeClass+NestedClass,MyAssembly

“++” 會變成 “\+\+”,而 “\” 會變成 “\\”。

這個限定名稱可以儲存,稍後用來載入 Type。 若要搜尋並載入 Type,請只搭配類型名稱或元件限定型別名稱使用 GetTypeGetType 具有型別名稱的 只會在呼叫端的元件中尋找 Type ,然後在 [系統] 元件中尋找 。 GetType 具有元件限定型別名稱的 ,將會在任何元件中尋找 Type

完整指定 AssemblyName 必須具有名稱、文化特性、公鑰或公鑰令牌、主要版本、次要版本、組建編號和修訂編號參數。 最後四個封裝在 Version 類型中。

若要建立簡單名稱,請使用無參數建構函式建立 AssemblyName 物件,並設定 Name。 其他屬性是選擇性的。

若要建立完整的強名稱,請使用無參數建構函式建立 AssemblyName 物件,並設定 NameKeyPair。 其他屬性是選擇性的。 使用 SetPublicKeySetPublicKeyToken 來設定公鑰和強名稱。 強名稱簽署一律使用 SHA1 哈希演算法。

若要確保正確建構名稱,請使用下列屬性:

您也可以搭配 /lGacutil.exe (全域程式集緩存工具使用 選項來取得名稱)

若為部分指定的強名稱,請使用無參數建構函式建立 AssemblyName 物件,並設定名稱和公鑰。 使用這類 AssemblyName 建立的元件稍後可以使用元件連結器 (Al.exe) 簽署。

您可以指定公鑰和 KeyPair 具有不一致值的 。 這在開發人員案例中很有用。 在此情況下,使用 GetPublicKey 擷取的公鑰會指定正確的公鑰,而 KeyPair 會指定開發期間使用的公用和私鑰。 當運行時間偵測到 與公鑰之間的不符時 KeyPair ,它會在登錄中查閱符合公鑰的正確機碼。

的顯示名稱格式是以逗號分隔的 AssemblyName Unicode 字串,開頭為名稱,如下所示:

Name <,Culture = CultureInfo> <,Version = Major.Minor.Build.Revision> <, StrongName> <,PublicKeyToken> '\0'

Name 是元件的文字名稱。 CultureInfo 是RFC1766格式定義的文化特性。 MajorMinorBuildRevision 是元件的主要版本、次要版本、組建編號和修訂編號。 StrongName 是使用 SHA-1 哈希演算法所產生的公鑰哈希值的十六進位編碼低序 64 位,以及所 SetPublicKey指定的公鑰。 PublicKeyToken 是 所 SetPublicKey指定的十六進位編碼公鑰。

十六進位編碼定義為將二進位物件的每個位元組轉換成兩個十六進位位元元,從最小到最重要的位元組。 系統會視需要新增其他顯示值。

如果已知完整的公鑰,則 PublicKey 可能會取代 StrongName。

另請注意,除了 Name必須先出現 ,參數的語彙順序並不重要。 不過,任何參數 (VersionCultureStrongNamePublicKey) 未特別設定,都會被視為省略,然後將 AssemblyName 視為部分。 指定部分資訊時,必須依上述順序指定 Name 參數。

提供顯示名稱時,慣例 StrongName =nullPublicKey= null 表示只需要對具名元件進行系結和比對。 此外,表示空字串的慣例 Culture= "" (雙引號,) 表示與預設文化特性相符。

下列範例示範 AssemblyName 具有預設文化特性之簡單具名元件的 。

ExampleAssembly, Culture=""

下例顯示具有 "en" 文化特性之強式名稱組件的完整指定參考。

ExampleAssembly, Version=1.0.0.0, Culture=en, PublicKeyToken=a5d015c7d5a0b012

建構函式

AssemblyName()

初始化 AssemblyName 類別的新執行個體。

AssemblyName(String)

使用指定的顯示名稱,初始化 AssemblyName 類別的新執行個體。

屬性

CodeBase
已淘汰.

取得或設定做為 URL 之組件的位置。

ContentType

取得或設定值,表示組件包含何種內容類型。

CultureInfo

取得或設定組件所支援的文化特性。

CultureName

取得或設定與組建相關聯的文化特性名稱。

EscapedCodeBase
已淘汰.

取得代表基礎碼的 URI,包括逸出字元。

Flags

取得或設定組件的屬性。

FullName

取得組件的完整名稱,也稱為顯示名稱。

HashAlgorithm
已淘汰.

取得或設定組件資訊清單 (Assembly Manifest) 所使用的雜湊演算法。

KeyPair
已淘汰.

取得或設定公開或私密的密碼編譯金鑰組,此金鑰組可用來建立組件的強式名稱簽章。

Name

取得或設定組件的簡單名稱。 這通常 (但不一定) 是組件之資訊清單檔的檔名 (不含其副檔名)。

ProcessorArchitecture
已淘汰.

取得或設定值,這個值可識別可執行檔之目標平台的處理器以及每個字組的位元 (Bits-per-word)。

Version

取得或設定組件的主要、次要、組建和修訂編號。

VersionCompatibility
已淘汰.

取得或設定與組件和其他組件相容性相關的資訊。

方法

Clone()

建立這個 AssemblyName 物件的複本。

Equals(Object)

判斷指定的物件是否等於目前的物件。

(繼承來源 Object)
GetAssemblyName(String)

取得指定檔案的 AssemblyName

GetHashCode()

做為預設雜湊函式。

(繼承來源 Object)
GetObjectData(SerializationInfo, StreamingContext)
已淘汰.

取得序列化 (Serialization) 資訊,包含重新建立這個 AssemblyName 執行個體所需的全部資料。

GetPublicKey()

取得組件的公開金鑰。

GetPublicKeyToken()

取得公開金鑰語彙基元,即是用於應用程式或組件簽名的公開金鑰 SHA-1 雜湊的最後 8 位元組。

GetType()

取得目前執行個體的 Type

(繼承來源 Object)
MemberwiseClone()

建立目前 Object 的淺層複製。

(繼承來源 Object)
OnDeserialization(Object)

實作 ISerializable 介面並在還原序列化完成時,由還原序列化事件回呼。

ReferenceMatchesDefinition(AssemblyName, AssemblyName)

傳回表示兩個組件名稱是否相同的值。 比較是根據簡單組件名稱進行。

SetPublicKey(Byte[])

設定可識別組件的公開金鑰。

SetPublicKeyToken(Byte[])

設定公開金鑰語彙基元,即是用於簽署應用程式或組件之公開金鑰 SHA-1 雜湊的最後 8 個位元組。

ToString()

傳回組件的完整名稱,也稱為顯示名稱。

明確介面實作

_AssemblyName.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr)

將一組名稱對應至一組對應的分派識別項 (Dispatch Identifier)。

_AssemblyName.GetTypeInfo(UInt32, UInt32, IntPtr)

擷取物件的類型資訊,可以用來取得介面的類型資訊。

_AssemblyName.GetTypeInfoCount(UInt32)

擷取物件提供的類型資訊介面數目 (0 或 1)。

_AssemblyName.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

提供物件所公開的屬性和方法的存取權。

適用於

另請參閱