AYUDA .NET

C# Reflection (Cómo funciona para desarrolladores)

Actualizado 27 de enero, 2024
Compartir:

En el mundo del desarrollo de software, C# es un lenguaje de programación versátil y potente que ofrece una amplia gama de funciones a los desarrolladores.

Una de ellas, que destaca por su flexibilidad y dinamismo, es la reflexión. Reflexión en C# permite a los desarrolladores inspeccionar e interactuar con los metadatos de los tipos durante el tiempo de ejecución. Esta capacidad abre una nueva dimensión de posibilidades, permitiendo a los desarrolladores crear aplicaciones más flexibles, extensibles y robustas.

En este artículo, nos adentraremos en los entresijos de la reflexión en C#, explorando sus conceptos clave, casos de uso y mejores prácticas. También encontraremos la información de reflexión del objeto PdfDocument de IronPDF.

Reflexión en C#

Reflection es un mecanismo que permite a un programa examinar y manipular su estructura y comportamiento en tiempo de ejecución. En C#, esto se consigue a través del espacio de nombres System.Reflection, que proporciona clases y métodos para interactuar con metadatos, obtener información sobre tipos e incluso crear instancias dinámicamente.

Componentes clave de la reflexión

Tipo Clase

En el núcleo de C# reflection se encuentra la clase Type, que representa un tipo en el tiempo de ejecución de .NET. Esta clase proporciona una gran cantidad de información acerca de un tipo, incluyendo todos los métodos públicos, propiedades, campos, eventos y parámetros de método.

Puede obtener un objeto Type para un tipo dado utilizando varios métodos, como el typeof() o llamando al operador GetType() sobre un objeto.

using System;

class Program
{
    static void Main()
    {
        //  Uso de typeof para obtener información sobre el tipo de cadena
        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()
    {
        //  Uso de typeof para obtener información sobre el tipo de cadena
        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()
		'  Uso de typeof para obtener información sobre el tipo de cadena
		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
VB   C#

Salida

C# Reflection (Cómo funciona para el desarrollador): Figura 1

Clase de montaje

Un ensamblado en .NET es una unidad de despliegue y versionado. La clase Assembly del espacio de nombres System.Reflection proporciona métodos para cargar y describir ensamblados e inspeccionar información de ensamblados dinámicamente.

Puede obtener un objeto Asamblea para cualquier instancia de la asamblea que se está ejecutando actualmente o para cualquier asamblea referenciada.

using System;
using System.Reflection;

class Program
{
    static void Main()
    {
        //  Ejemplo 1: Obtener información sobre el conjunto en ejecución
        Assembly executingAssembly = Assembly.GetExecutingAssembly();
        Console.WriteLine("Information about the executing assembly:");
        DisplayAssemblyInfo(executingAssembly);

        //  Ejemplo 2: Cargar el ensamblado mscorlib
        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()
    {
        //  Ejemplo 1: Obtener información sobre el conjunto en ejecución
        Assembly executingAssembly = Assembly.GetExecutingAssembly();
        Console.WriteLine("Information about the executing assembly:");
        DisplayAssemblyInfo(executingAssembly);

        //  Ejemplo 2: Cargar el ensamblado mscorlib
        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()
		'  Ejemplo 1: Obtener información sobre el conjunto en ejecución
		Dim executingAssembly As System.Reflection.Assembly = System.Reflection.Assembly.GetExecutingAssembly()
		Console.WriteLine("Information about the executing assembly:")
		DisplayAssemblyInfo(executingAssembly)

		'  Ejemplo 2: Cargar el ensamblado mscorlib
		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
VB   C#

Salida

C# Reflection (Cómo funciona para el desarrollador): Figura 2

Clases MethodInfo, PropertyInfo, FieldInfo y EventInfo

Estas clases representan miembros públicos, métodos, propiedades, campos y eventos, respectivamente. Exponen información sobre estos miembros, como sus nombres, tipos, accesibilidad, etc.

Puede obtener acceso a instancias de estas clases a través de la clase 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()
    {
        //  Obtener MethodInfo para MyMethod
        MethodInfo methodInfo = typeof(MyClass).GetMethod("MyMethod");
        Console.WriteLine($"Method Name: {methodInfo.Name}");

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

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

        //  Obtener EventInfo para 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()
    {
        //  Obtener MethodInfo para MyMethod
        MethodInfo methodInfo = typeof(MyClass).GetMethod("MyMethod");
        Console.WriteLine($"Method Name: {methodInfo.Name}");

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

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

        //  Obtener EventInfo para 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()
		'  Obtener MethodInfo para MyMethod
		Dim methodInfo As MethodInfo = GetType([MyClass]).GetMethod("MyMethod")
		Console.WriteLine($"Method Name: {methodInfo.Name}")

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

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

		'  Obtener EventInfo para MyEvent
		Dim eventInfo As EventInfo = GetType([MyClass]).GetEvent("MyEvent")
		Console.WriteLine($"Event Name: {eventInfo.Name}")
	End Sub
End Class
VB   C#

Salida

C# Reflection (Cómo funciona para el desarrollador): Figura 3

Presentación de IronPDF

IronPDF es una potente biblioteca de C# que ofrece un completo conjunto de funciones para trabajar con documentos PDF en aplicaciones .NET. Permite a los desarrolladores crear, manipular y extraer fácilmente datos de un objeto existente, como archivos PDF, mediante una API sencilla e intuitiva.

Una característica notable de IronPDF es su capacidad para integrarse perfectamente con proyectos C# existentes, lo que lo convierte en una excelente opción para añadir capacidades de generación y manipulación de PDF.

Características principales de IronPDF

Algunas características clave de IronPDF son las siguientes:

  1. Generación de PDF: Genera fácilmente documentos PDF desde cero o convierte HTML, imágenes y otros formatos a PDF.
  2. Manipulación de PDF: Edite los PDF existentes añadiendo, eliminando o modificando texto, imágenes y anotaciones.
  3. Extracción de PDF: Extrae texto, imágenes y metadatos de archivos PDF para su posterior procesamiento.
  4. Conversión de HTML a PDF: Convierte contenidos HTML, incluidos CSS y JavaScript, en PDF de alta calidad.
  5. Formularios PDF: Cree y rellene formularios PDF interactivos mediante programación.
  6. Seguridad: Aplique encriptación y protección por contraseña para proteger los documentos PDF.

    Ahora, vamos a explorar cómo utilizar C# reflection con IronPDF en un ejemplo de código detallado.

Uso de C# Reflexión con IronPDF

En este sencillo ejemplo, obtendremos la información sobre el objeto de documento PDF IronPDF utilizando C# reflection.

Instalar el paquete NuGet IronPDF

Asegúrese de instalar el paquete IronPDF NuGet en su proyecto. Puede hacerlo utilizando la consola del gestor de paquetes NuGet:

Install-Package IronPdf

Uso de C# Reflection para obtener datos del objeto de documento PDF IronPDF

using IronPdf;
using System;

Type PDF = typeof(PdfDocument);
Console.WriteLine("Information about the PdfDocument type:");
Console.WriteLine($"Type Name: {PDF.Name}");
Console.WriteLine($"Full Name: {PDF.FullName}");
Console.WriteLine($"Assembly Qualified Name: {PDF.AssemblyQualifiedName}");
Console.WriteLine("\nMembers:");
foreach (var memberInfo in PDF.GetMembers())
{
    Console.WriteLine($"{memberInfo.MemberType} {memberInfo.Name}");
}
using IronPdf;
using System;

Type PDF = typeof(PdfDocument);
Console.WriteLine("Information about the PdfDocument type:");
Console.WriteLine($"Type Name: {PDF.Name}");
Console.WriteLine($"Full Name: {PDF.FullName}");
Console.WriteLine($"Assembly Qualified Name: {PDF.AssemblyQualifiedName}");
Console.WriteLine("\nMembers:");
foreach (var memberInfo in PDF.GetMembers())
{
    Console.WriteLine($"{memberInfo.MemberType} {memberInfo.Name}");
}
Imports Microsoft.VisualBasic
Imports IronPdf
Imports System

Private PDF As Type = GetType(PdfDocument)
Console.WriteLine("Information about the PdfDocument type:")
Console.WriteLine($"Type Name: {PDF.Name}")
Console.WriteLine($"Full Name: {PDF.FullName}")
Console.WriteLine($"Assembly Qualified Name: {PDF.AssemblyQualifiedName}")
Console.WriteLine(vbLf & "Members:")
For Each memberInfo In PDF.GetMembers()
	Console.WriteLine($"{memberInfo.MemberType} {memberInfo.Name}")
Next memberInfo
VB   C#

El código C# proporcionado utiliza reflection para obtener información sobre el tipo PdfDocument de la librería IronPDF. Inicialmente, el typeof(DocumentoPdf)se utiliza para recuperar el objetoType` que representa el tipo PdfDocument.

Posteriormente, varias propiedades del objeto Type obtenido se imprimen en la consola, incluyendo el nombre del tipo, el nombre completo y el nombre cualificado por el ensamblador.

Además, el código utiliza un bucle foreach para recorrer los miembros del tipo PdfDocument, imprimiendo información sobre cada miembro, como su tipo y nombre.

Este enfoque muestra el uso de la reflexión para inspeccionar dinámicamente la estructura y los metadatos de los objetos del tipo PdfDocument durante el tiempo de ejecución, proporcionando información sobre la composición y todos los miembros públicos de la clase PdfDocument de la biblioteca IronPDF.

Salida:

C# Reflection (Cómo funciona para el desarrollador): Figura 4

Conclusión

C# reflection es un potente mecanismo que permite a los desarrolladores inspeccionar y manipular dinámicamente la estructura de los tipos en tiempo de ejecución.

Este artículo ha explorado los conceptos clave, los casos de uso y las mejores prácticas asociadas a la reflexión en C#, destacando su importancia en la creación de aplicaciones flexibles y extensibles.

Además, la integración de IronPDF, una robusta biblioteca de manipulación de PDF, demuestra aún más la versatilidad de C# reflection para obtener información sobre el tipo PdfDocument de forma dinámica.

A medida que los desarrolladores aprovechan estas capacidades, obtienen la flexibilidad necesaria para adaptar sus aplicaciones a requisitos y escenarios cambiantes, lo que pone de manifiesto la naturaleza dinámica de C# y las valiosas aportaciones de bibliotecas como IronPDF para mejorar las capacidades de procesamiento de documentos.

IronPDF es una biblioteca bien documentada con muchos tutoriales sobre cómo utilizar IronPDF. Para ver los tutoriales, visite aquí que ofrece a los desarrolladores una mayor oportunidad de conocer sus características.

< ANTERIOR
NPlot C# (Cómo funciona para desarrolladores)
SIGUIENTE >
Npgsql C# .NET (Cómo funciona para desarrolladores)

¿Listo para empezar? Versión: 2024.7 recién publicada

Descarga gratuita de NuGet Descargas totales: 9,974,197 Ver licencias >
123