跳過到頁腳內容
.NET幫助

C# 反射(對於開發者的運行原理)

在軟體開發的世界裡,C# 是一種多功能且功能強大的程式語言,提供開發人員多樣的功能。

其中一個以靈活性和動態性最為突出的功能就是反射。 C#中的反射允許開發人員在執行期間檢查類型的元資料並與之互動。這項功能開啟了新的可能性層面,使開發人員能夠建立更靈活、可擴充且更穩健的應用程式。

在這篇文章中,我們將深入探討 C# 反射的複雜性,探索其主要概念、使用案例和最佳實務。 我們也會找到 IronPDFPdfDocument 物件的反射資訊。

C# 中的反射

反射(Reflection)是一種機制,允許程式在執行時檢查並操縱其結構與行為。在 C# 中,這是透過 System.Reflection 命名空間來實現的,該命名空間提供了與元資料互動、獲取類型資訊,甚至動態建立實體的類別和方法。

反射的主要組成部分

類型類別

C# 反射的核心是 Type 類,它代表 .NET 運行時中的類型。這個類別提供了關於一個類型的大量資訊,包括所有的公用方法、屬性、欄位、事件和方法參數。

您可以使用各種方法取得給定類型的 Type 物件,例如 typeof() 運算子或呼叫物件上的 GetType() 方法。

using System;

class Program
{
    static void Main()
    {
        // Using typeof to get Type information for string
        Type stringType = typeof(string);
        Console.WriteLine("Information about the string type:");
        Console.WriteLine($"Type Name: {stringType.Name}");
        Console.WriteLine($"Full Name: {stringType.FullName}");
        Console.WriteLine($"Assembly Qualified Name: {stringType.AssemblyQualifiedName}");
    }
}
using System;

class Program
{
    static void Main()
    {
        // Using typeof to get Type information for string
        Type stringType = typeof(string);
        Console.WriteLine("Information about the string type:");
        Console.WriteLine($"Type Name: {stringType.Name}");
        Console.WriteLine($"Full Name: {stringType.FullName}");
        Console.WriteLine($"Assembly Qualified Name: {stringType.AssemblyQualifiedName}");
    }
}
Imports System

Friend Class Program
	Shared Sub Main()
		' Using typeof to get Type information for string
		Dim stringType As Type = GetType(String)
		Console.WriteLine("Information about the string type:")
		Console.WriteLine($"Type Name: {stringType.Name}")
		Console.WriteLine($"Full Name: {stringType.FullName}")
		Console.WriteLine($"Assembly Qualified Name: {stringType.AssemblyQualifiedName}")
	End Sub
End Class
$vbLabelText   $csharpLabel

輸出

C# Reflection (How It Works For Developer):圖 1

組裝類

.NET 中的程序集是部署和版本控制的單位。 System.Reflection 命名空間中的 Assembly 類提供載入和描述程序集以及動態檢查程序集資訊的方法。

您可以為目前執行的程式集的任何實例或任何引用的程式集取得 Assembly 物件。

using System;
using System.Reflection;

class Program
{
    static void Main()
    {
        // Example 1: Get information about the executing assembly
        Assembly executingAssembly = Assembly.GetExecutingAssembly();
        Console.WriteLine("Information about the executing assembly:");
        DisplayAssemblyInfo(executingAssembly);

        // Example 2: Load the mscorlib assembly
        Assembly mscorlibAssembly = Assembly.Load("mscorlib");
        Console.WriteLine("\nInformation about the mscorlib assembly:");
        DisplayAssemblyInfo(mscorlibAssembly);
    }

    static void DisplayAssemblyInfo(Assembly assembly)
    {
        Console.WriteLine($"Assembly Name: {assembly.GetName().Name}");
        Console.WriteLine($"Full Name: {assembly.FullName}");
        Console.WriteLine($"Location: {assembly.Location}");
        Console.WriteLine("\nModules:");

        foreach (var module in assembly.GetModules())
        {
            Console.WriteLine($"- {module.Name}");
        }

        Console.WriteLine(new string('-', 30));
    }
}
using System;
using System.Reflection;

class Program
{
    static void Main()
    {
        // Example 1: Get information about the executing assembly
        Assembly executingAssembly = Assembly.GetExecutingAssembly();
        Console.WriteLine("Information about the executing assembly:");
        DisplayAssemblyInfo(executingAssembly);

        // Example 2: Load the mscorlib assembly
        Assembly mscorlibAssembly = Assembly.Load("mscorlib");
        Console.WriteLine("\nInformation about the mscorlib assembly:");
        DisplayAssemblyInfo(mscorlibAssembly);
    }

    static void DisplayAssemblyInfo(Assembly assembly)
    {
        Console.WriteLine($"Assembly Name: {assembly.GetName().Name}");
        Console.WriteLine($"Full Name: {assembly.FullName}");
        Console.WriteLine($"Location: {assembly.Location}");
        Console.WriteLine("\nModules:");

        foreach (var module in assembly.GetModules())
        {
            Console.WriteLine($"- {module.Name}");
        }

        Console.WriteLine(new string('-', 30));
    }
}
Imports Microsoft.VisualBasic
Imports System
Imports System.Reflection

Friend Class Program
	Shared Sub Main()
		' Example 1: Get information about the executing assembly
		Dim executingAssembly As System.Reflection.Assembly = System.Reflection.Assembly.GetExecutingAssembly()
		Console.WriteLine("Information about the executing assembly:")
		DisplayAssemblyInfo(executingAssembly)

		' Example 2: Load the mscorlib assembly
		Dim mscorlibAssembly As System.Reflection.Assembly = System.Reflection.Assembly.Load("mscorlib")
		Console.WriteLine(vbLf & "Information about the mscorlib assembly:")
		DisplayAssemblyInfo(mscorlibAssembly)
	End Sub

	Private Shared Sub DisplayAssemblyInfo(ByVal assembly As System.Reflection.Assembly)
		Console.WriteLine($"Assembly Name: {assembly.GetName().Name}")
		Console.WriteLine($"Full Name: {assembly.FullName}")
		Console.WriteLine($"Location: {assembly.Location}")
		Console.WriteLine(vbLf & "Modules:")

		For Each [module] In assembly.GetModules()
			Console.WriteLine($"- {[module].Name}")
		Next [module]

		Console.WriteLine(New String("-"c, 30))
	End Sub
End Class
$vbLabelText   $csharpLabel

輸出

C# Reflection (How It Works For Developer):圖 2

MethodInfo、PropertyInfo、FieldInfo 和 EventInfo 類別。

這些類別分別代表公共成員、方法、屬性、欄位和事件。 他們會揭露這些成員的相關資訊,例如名稱、類型、可存取性等。

您可以透過 Type 類別取得這些類別的實體。

using System;
using System.Reflection;

class MyClass
{
    public void MyMethod() { }
    public int MyProperty { get; set; }
    public string myField;
    public event EventHandler MyEvent;
}

class Program
{
    static void Main()
    {
        // Get MethodInfo for MyMethod
        MethodInfo methodInfo = typeof(MyClass).GetMethod("MyMethod");
        Console.WriteLine($"Method Name: {methodInfo.Name}");

        // Get PropertyInfo for MyProperty
        PropertyInfo propertyInfo = typeof(MyClass).GetProperty("MyProperty");
        Console.WriteLine($"Property Name: {propertyInfo.Name}");

        // Get FieldInfo for myField
        FieldInfo fieldInfo = typeof(MyClass).GetField("myField");
        Console.WriteLine($"Field Name: {fieldInfo.Name}");

        // Get EventInfo for MyEvent
        EventInfo eventInfo = typeof(MyClass).GetEvent("MyEvent");
        Console.WriteLine($"Event Name: {eventInfo.Name}");
    }
}
using System;
using System.Reflection;

class MyClass
{
    public void MyMethod() { }
    public int MyProperty { get; set; }
    public string myField;
    public event EventHandler MyEvent;
}

class Program
{
    static void Main()
    {
        // Get MethodInfo for MyMethod
        MethodInfo methodInfo = typeof(MyClass).GetMethod("MyMethod");
        Console.WriteLine($"Method Name: {methodInfo.Name}");

        // Get PropertyInfo for MyProperty
        PropertyInfo propertyInfo = typeof(MyClass).GetProperty("MyProperty");
        Console.WriteLine($"Property Name: {propertyInfo.Name}");

        // Get FieldInfo for myField
        FieldInfo fieldInfo = typeof(MyClass).GetField("myField");
        Console.WriteLine($"Field Name: {fieldInfo.Name}");

        // Get EventInfo for MyEvent
        EventInfo eventInfo = typeof(MyClass).GetEvent("MyEvent");
        Console.WriteLine($"Event Name: {eventInfo.Name}");
    }
}
Imports System
Imports System.Reflection

Friend Class [MyClass]
	Public Sub MyMethod()
	End Sub
	Public Property MyProperty() As Integer
	Public myField As String
	Public Event MyEvent As EventHandler
End Class

Friend Class Program
	Shared Sub Main()
		' Get MethodInfo for MyMethod
		Dim methodInfo As MethodInfo = GetType([MyClass]).GetMethod("MyMethod")
		Console.WriteLine($"Method Name: {methodInfo.Name}")

		' Get PropertyInfo for MyProperty
		Dim propertyInfo As PropertyInfo = GetType([MyClass]).GetProperty("MyProperty")
		Console.WriteLine($"Property Name: {propertyInfo.Name}")

		' Get FieldInfo for myField
		Dim fieldInfo As FieldInfo = GetType([MyClass]).GetField("myField")
		Console.WriteLine($"Field Name: {fieldInfo.Name}")

		' Get EventInfo for MyEvent
		Dim eventInfo As EventInfo = GetType([MyClass]).GetEvent("MyEvent")
		Console.WriteLine($"Event Name: {eventInfo.Name}")
	End Sub
End Class
$vbLabelText   $csharpLabel

輸出

C# Reflection (How It Works For Developer):圖 3

介紹 IronPDF。

IronPDF - 官方網站是一個功能強大的 C# 函式庫,提供在 .NET 應用程式中處理 PDF 文件的全面功能。 它允許開發人員使用簡單直觀的 API,輕鬆地從 PDF 檔案等現有物件中建立、處理和擷取資料。

IronPDF 的一個顯著特點是能夠與現有的 C# 專案無縫整合,使其成為新增 PDF 生成和處理功能的絕佳選擇。

IronPDF 的主要功能

IronPDF 的一些主要功能如下:

1.PDF生成:輕鬆地從零開始生成PDF文件,或將HTML、圖像和其他格式轉換為PDF。 2.PDF 處理:透過新增、移除或修改文字、影像和註解來編輯現有的 PDF。 3.PDF 擷取:從 PDF 檔案中擷取文字、影像和元資料,以便進一步處理。 4.HTML 至 PDF 轉換: 將 HTML 內容(包括 CSS 和 JavaScript)轉換為高品質的 PDF。 5.PDF 表單: 以程式化方式建立和填寫互動式 PDF 表單。 6.安全性:應用加密和密碼保護來保護 PDF 文件。

現在,讓我們在詳細的程式碼範例中探討如何使用 IronPDF 的 C# 反射。

使用 IronPDF 的 C# 反射。

在這個簡單的範例中,我們將使用 C# 反射來取得 IronPDF PDF 文件物件的相關資訊。

安裝 IronPDF NuGet 套件。

請務必安裝 IronPDF NuGet 套件到您的專案中。 您可以使用 NuGet Package Manager Console 進行此工作:

Install-Package IronPdf

使用 C# Reflection 取得 IronPDF PDF 文件物件的資料。

using IronPdf;
using System;
using System.Reflection;

class Program
{
    static void Main()
    {
        // Get the Type object representing PdfDocument
        Type pdfDocumentType = typeof(PdfDocument);

        // Display basic information about the PdfDocument type
        Console.WriteLine("Information about the PdfDocument type:");
        Console.WriteLine($"Type Name: {pdfDocumentType.Name}");
        Console.WriteLine($"Full Name: {pdfDocumentType.FullName}");
        Console.WriteLine($"Assembly Qualified Name: {pdfDocumentType.AssemblyQualifiedName}");
        Console.WriteLine("\nMembers:");

        // Iterate over all members and display their information
        foreach (var memberInfo in pdfDocumentType.GetMembers())
        {
            Console.WriteLine($"{memberInfo.MemberType} {memberInfo.Name}");
        }
    }
}
using IronPdf;
using System;
using System.Reflection;

class Program
{
    static void Main()
    {
        // Get the Type object representing PdfDocument
        Type pdfDocumentType = typeof(PdfDocument);

        // Display basic information about the PdfDocument type
        Console.WriteLine("Information about the PdfDocument type:");
        Console.WriteLine($"Type Name: {pdfDocumentType.Name}");
        Console.WriteLine($"Full Name: {pdfDocumentType.FullName}");
        Console.WriteLine($"Assembly Qualified Name: {pdfDocumentType.AssemblyQualifiedName}");
        Console.WriteLine("\nMembers:");

        // Iterate over all members and display their information
        foreach (var memberInfo in pdfDocumentType.GetMembers())
        {
            Console.WriteLine($"{memberInfo.MemberType} {memberInfo.Name}");
        }
    }
}
Imports Microsoft.VisualBasic
Imports IronPdf
Imports System
Imports System.Reflection

Friend Class Program
	Shared Sub Main()
		' Get the Type object representing PdfDocument
		Dim pdfDocumentType As Type = GetType(PdfDocument)

		' Display basic information about the PdfDocument type
		Console.WriteLine("Information about the PdfDocument type:")
		Console.WriteLine($"Type Name: {pdfDocumentType.Name}")
		Console.WriteLine($"Full Name: {pdfDocumentType.FullName}")
		Console.WriteLine($"Assembly Qualified Name: {pdfDocumentType.AssemblyQualifiedName}")
		Console.WriteLine(vbLf & "Members:")

		' Iterate over all members and display their information
		For Each memberInfo In pdfDocumentType.GetMembers()
			Console.WriteLine($"{memberInfo.MemberType} {memberInfo.Name}")
		Next memberInfo
	End Sub
End Class
$vbLabelText   $csharpLabel

所提供的 C# 程式碼利用反射從 IronPDF 函式庫取得 PdfDocument 類型的相關資訊。 最初,使用 typeof(PdfDocument) 表達式檢索表示PdfDocument類型的 Type 物件。

隨後,將取得的 Type 物件的各種屬性列印到控制台,包括類型名稱、完整名稱和彙編限定名稱。

此外,程式碼利用迴圈遍歷PdfDocument類型的成員,列印有關每個成員的信息,例如其成員類型和名稱。

本方法展示了使用反射在運行期間動態檢查 PdfDocument 類型物件的結構和元資料,提供對 IronPDF 函式庫的 PdfDocument 類的組成和所有公共成員的深入瞭解。

輸出:

C# Reflection (How It Works For Developer):圖 4

結論

C# 反射是一種強大的機制,可讓開發人員在執行時動態檢查和操作類型的結構。

本文探討了與 C# 反射相關的關鍵概念、使用案例和最佳實務,強調其在建立彈性和可擴充應用程式中的重要性。

此外,整合了 IronPDF 這個強大的 PDF 操作函式庫,進一步展示了 C# 反映在動態取得 PdfDocument 類型資訊方面的多功能性。

當開發人員運用這些功能時,他們可以靈活地調整他們的應用程式,以適應不斷變化的需求和情境,展現 C# 的動態特性,以及 IronPDF 等函式庫在增強文件處理能力方面的寶貴貢獻。

IronPDF 是一個文件完備的函式庫,有許多教學。 如需查看教程,請造訪 IronPDF 教程文件,它為開發人員提供了更多了解其功能的機會。

常見問題解答

什麼是C#反射及其重要性?

C#反射是一項允許開發者在運行時檢查和操作類型元資料的功能。它很重要,因為它在應用程式開發中提供了靈活性和動態性,使開發者能創建更具適應性和可擴展的軟體。

如何使用反射在C#中與PDF文檔互動?

您可以使用C#反射來動態獲取IronPDF中的PdfDocument類型的信息。這允許您在運行時檢查PdfDocument類的結構、組成和公共成員,方便動態PDF文檔操作。

C#反射的一些常見使用例是什麼?

C#反射的常見使用例包括動態類型檢查、創建可擴展應用程式、訪問元資料、動態加載組件和自動化代碼生成。它增強了軟體開發的靈活性和適應性。

Type類如何促進C#中的反射?

C#中的Type類提供了類型的信息,如其方法、屬性、字段和事件。開發者可以使用typeof()運算符或GetType()方法獲取Type對象,並使用它來訪問元資料,使得動態檢查和類型的交互成為可能。

能否舉例說明如何使用IronPDF進行反射?

使用IronPDF進行反射的一個例子是獲得PdfDocument對象的反射信息。這讓開發者可以動態檢查PDF文檔的結構和元資料,展示IronPDF在PDF生成、操作和提取方面的能力。

開發者在使用C#反射時應考慮什麼?

在使用C#反射時,開發者應考慮將其使用降至最低以減少潛在的性能開銷,確保安全處理動態加載的類型,並謹慎使用反射以確保其好處超過成本的情況下使用。

Assembly類如何在C#反射中被利用?

System.Reflection中的Assembly類提供了加載和檢查組件的方法。它讓開發者可以訪問組件元資料,探索模塊信息,並在運行時動態加載和描述組件,促進動態軟體管理。

將PDF庫與C#集成有什麼優勢?

將像IronPDF這樣的PDF庫與C#集成使開發者可以無縫地將PDF生成和操作功能添加到他們的應用程式中。它提供了PDF創建、編輯、表單處理和安全性等功能,增強.NET應用程式中的文檔處理工作流程。

Jacob Mellor, Team Iron 首席技術官
首席技術官

Jacob Mellor是Iron Software的首席技術官,也是開創C# PDF技術的前瞻性工程師。作為Iron Software核心代碼庫的原始開發者,他自公司成立以來就塑造了公司的產品架構,並與CEO Cameron Rimington將公司轉型為服務NASA、Tesla以及全球政府機構的50多人公司。

Jacob擁有曼徹斯特大學土木工程一級榮譽學士學位(1998年–2001年)。他於1999年在倫敦開立首家軟體公司,並於2005年建立了他的第一個.NET組件,專注於解決Microsoft生態系統中的複雜問題。

他的旗艦作品IronPDF和Iron Suite .NET程式庫全球已獲得超過3000萬次NuGet安裝,他的基礎代碼不斷在全球各地驅動開發者工具。擁有25年以上的商業經驗和41年的編碼專業知識,Jacob仍然專注於推動企業級C#、Java和Python PDF技術的創新,同時指導下一代技術領導者。

鋼鐵支援團隊

我們每週 5 天,每天 24 小時在線上。
聊天
電子郵件
打電話給我