AYUDA .NET

C# Ref (Cómo funciona para desarrolladores)

Actualizado 29 de abril, 2024
Compartir:

En C#, la función palabra clave ref es una potente función que permite a los métodos modificar el valor del parámetro de variables de tipo referencia pasadas. Comprender cómo utilizar ref puede mejorar su capacidad para gestionar y manipular datos dentro de sus aplicaciones.

Este artículo le guiará a través de los conceptos básicos de la palabra clave ref, su aplicación y los matices de su uso con diferentes tipos de datos. También aprenderemos sobre Biblioteca IronPDF que es una biblioteca PDF.

Comprender los parámetros de referencia

Un parámetro ref es un parámetro de método que actúa como referencia a la variable pasada al método. A diferencia de los parámetros de valor estándar, en los que sólo se pasa una copia de la variable, los parámetros ref permiten al método llamado modificar el valor de la variable original. Este comportamiento es crucial cuando se necesita que un método actualice el estado de las variables que se le pasan.

Considere el siguiente ejemplo para demostrar el uso básico de ref, centrándose en cómo una variable de tipo referencia conserva su valor de parámetro en el mismo objeto a lo largo de las llamadas a métodos:

class Program
{
    static void Main()
    {
        int number = 100;
        ModifyNumber(ref number);
        Console.WriteLine(number);
    }
    static void ModifyNumber(ref int number)
    {
        number = 200;
    }
}
class Program
{
    static void Main()
    {
        int number = 100;
        ModifyNumber(ref number);
        Console.WriteLine(number);
    }
    static void ModifyNumber(ref int number)
    {
        number = 200;
    }
}
Friend Class Program
	Shared Sub Main()
		Dim number As Integer = 100
		ModifyNumber(number)
		Console.WriteLine(number)
	End Sub
	Private Shared Sub ModifyNumber(ByRef number As Integer)
		number = 200
	End Sub
End Class
VB   C#

En este ejemplo, el método Main declara un número entero number y lo inicializa a 100. Luego llama a ModifyNumber pasando number como parámetro ref. A continuación, llama a ModificarNúmero, pasando número como parámetro ref. Dentro de ModificarNúmero, el valor de número se cambia a 200. Como number se pasa por referencia, el cambio se refleja en el valor original en el método Main, y 200 se imprime en la consola.

Cómo funcionan los parámetros de referencia

Cuando declaras un parámetro de método con la palabra clave ref, le estás diciendo al compilador que el parámetro hará referencia a la variable original en lugar de a una copia. Esto se consigue pasando la dirección de memoria de la variable, en lugar del valor real. Tanto el método llamado como el método invocador acceden a la misma posición de memoria, lo que significa que cualquier cambio realizado en el parámetro se realiza directamente en la variable original.

La clave para entender ref es reconocer que puede utilizarse tanto con tipos de valor como con tipos de referencia. Los tipos de valor incluyen tipos de datos simples como enteros y structs, mientras que los tipos de referencia incluyen objetos y arrays. Sin embargo, aunque las variables de tipo referencia contienen intrínsecamente direcciones de memoria, el uso de ref con tipos de referencia permite modificar la referencia real, no sólo el contenido del objeto.

Diferencias entre ref y out

Aunque ambas palabras clave ref y out permiten modificar las variables originales, existen importantes distinciones. Un parámetro out no requiere inicialización antes de ser pasado a un método. Por el contrario, un parámetro ref requiere que la variable sea inicializada antes de ser pasada. Además, un método que utilice un parámetro out está obligado a asignar un valor antes de que el método retorne. Este requisito no se aplica a los parámetros ref.

Así es como se puede utilizar la palabra clave out:

class Program
{
    static void Main()
    {
        int result;
        CalculateResult(out result);
        Console.WriteLine(result);
    }
    static void CalculateResult(out int calculation)
    {
        calculation = 20 * 5;
    }
}
class Program
{
    static void Main()
    {
        int result;
        CalculateResult(out result);
        Console.WriteLine(result);
    }
    static void CalculateResult(out int calculation)
    {
        calculation = 20 * 5;
    }
}
Friend Class Program
	Shared Sub Main()
		Dim result As Integer = Nothing
		CalculateResult(result)
		Console.WriteLine(result)
	End Sub
	Private Shared Sub CalculateResult(ByRef calculation As Integer)
		calculation = 20 * 5
	End Sub
End Class
VB   C#

En este caso, CalculateResult inicializa el cálculo dentro del método, y Main refleja el resultado.

Uso práctico de ref en la sobrecarga de métodos

ref también se puede utilizar en la sobrecarga de métodos, donde la firma del método es alterada por la palabra clave ref. Las firmas de los métodos están compuestas por el nombre del método y los tipos de sus parámetros, incluyendo si los parámetros se pasan por referencia (ref), por valor, o como parámetro out.

Considerar la sobrecarga de métodos basados en ref y parámetros de valor:

class Program
{
    static void Main()
    {
        int normalParameter = 10, refParameter = 10;
        IncrementValue(normalParameter);
        IncrementValue(ref refParameter);
        Console.WriteLine($"Normal: {normalParameter}, Ref: {refParameter}");
    }
    static void IncrementValue(int number)
    {
        number++;
    }
    static void IncrementValue(ref int number)
    {
        number++;
    }
}
class Program
{
    static void Main()
    {
        int normalParameter = 10, refParameter = 10;
        IncrementValue(normalParameter);
        IncrementValue(ref refParameter);
        Console.WriteLine($"Normal: {normalParameter}, Ref: {refParameter}");
    }
    static void IncrementValue(int number)
    {
        number++;
    }
    static void IncrementValue(ref int number)
    {
        number++;
    }
}
Friend Class Program
	Shared Sub Main()
		Dim normalParameter As Integer = 10, refParameter As Integer = 10
		IncrementValue(normalParameter)
		IncrementValue(refParameter)
		Console.WriteLine($"Normal: {normalParameter}, Ref: {refParameter}")
	End Sub
'INSTANT VB TODO TASK: VB does not allow method overloads which differ only in parameter ByVal/ByRef:
'ORIGINAL LINE: static void IncrementValue(int number)
	Private Shared Sub IncrementValue(ByVal number As Integer)
		number += 1
	End Sub
'INSTANT VB TODO TASK: VB does not allow method overloads which differ only in parameter ByVal/ByRef:
'ORIGINAL LINE: static void IncrementValue(ref int number)
	Private Shared Sub IncrementValue(ByRef number As Integer)
		number += 1
	End Sub
End Class
VB   C#

Aquí, IncrementValue está sobrecargado con una versión que toma un parámetro normal y otra que toma un parámetro ref. La versión ref incrementa la variable original, mientras que la versión normal sólo modifica una copia.

Introducción a IronPDF

C# Ref (Cómo funciona para los desarrolladores): Figura 1

IronPDF es una completa biblioteca .NET diseñada para trabajar con documentos PDF. Está construido principalmente en C# y se centra en simplificar la creación y manipulación de PDF a partir de contenido HTML. Al emplear un motor de renderizado de Chrome, IronPDF proporciona documentos PDF de alta calidad y con píxeles perfectos que capturan los matices del contenido HTML, CSS, JavaScript e imágenes.

Esta biblioteca es versátil y compatible con una amplia gama de entornos .NET, incluidos .NET Framework, .NET Core y .NET Standard, lo que la hace adecuada para diversas aplicaciones, desde sistemas de escritorio hasta sistemas basados en web. IronPDF no sólo permite crear PDF, sino que también ofrece funciones de edición, protección y conversión de PDF a otros formatos.

Esta capacidad se extiende a la extracción de texto e imágenes, el rellenado de formularios e incluso la aplicación de firmas digitales, lo que garantiza un manejo completo de los documentos PDF dentro de las aplicaciones .NET.

Integración de IronPDF con C# y ref Palabra clave

IronPDF puede integrarse con C# para aprovechar las sólidas características del lenguaje, incluido el uso de la palabra clave ref para pasar parámetros por referencia. Esta integración permite generar PDF dinámicos cuyo contenido puede depender de variables cuyos valores se determinan en tiempo de ejecución.

Para ilustrar la integración de IronPDF con C# utilizando la palabra clave ref, considere un escenario en el que queremos generar un informe PDF que incluya un valor calculado dinámicamente. Este valor se calculará dentro de un método que acepte un parámetro ref, lo que permitirá al método modificar este valor, que luego se reflejará en el PDF generado.

Ejemplo de código: Generación de un PDF con contenido dinámico mediante ref

El siguiente código C# demuestra cómo utilizar IronPDF junto con la palabra clave ref para generar un documento PDF. El código calcula un valor, lo modifica mediante un método que acepta un parámetro ref y, a continuación, utiliza IronPDF para generar un PDF que incluya este contenido dinámico.

using IronPdf;
using System;
class Program
{
    static void Main(string [] args)
    {
        License.LicenseKey = "License-Key";
        //  Inicializar el valor
        int totalSales = 150;
        //  Modificar el valor dentro del método utilizando 'ref'.
        AddMonthlyBonus(ref totalSales);
        //  Utilice IronPDF para generar un informe en PDF
        var Renderer = new ChromePdfRenderer();
        var PDF = Renderer.RenderHtmlAsPdf($"<h1>Monthly Sales Report</h1><p>Total Sales, including bonus: {totalSales}</p>");
        //  Guardar el PDF en un archivo
        PDF.SaveAs("MonthlySalesReport.pdf");
        //  Confirmar que se ha generado el PDF
        Console.WriteLine("PDF generated successfully. Check your project directory.");
    }
    static void AddMonthlyBonus(ref int sales)
    {
        //  Supongamos una bonificación del 10% de las ventas
        sales += (int)(sales * 0.1);
    }
}
using IronPdf;
using System;
class Program
{
    static void Main(string [] args)
    {
        License.LicenseKey = "License-Key";
        //  Inicializar el valor
        int totalSales = 150;
        //  Modificar el valor dentro del método utilizando 'ref'.
        AddMonthlyBonus(ref totalSales);
        //  Utilice IronPDF para generar un informe en PDF
        var Renderer = new ChromePdfRenderer();
        var PDF = Renderer.RenderHtmlAsPdf($"<h1>Monthly Sales Report</h1><p>Total Sales, including bonus: {totalSales}</p>");
        //  Guardar el PDF en un archivo
        PDF.SaveAs("MonthlySalesReport.pdf");
        //  Confirmar que se ha generado el PDF
        Console.WriteLine("PDF generated successfully. Check your project directory.");
    }
    static void AddMonthlyBonus(ref int sales)
    {
        //  Supongamos una bonificación del 10% de las ventas
        sales += (int)(sales * 0.1);
    }
}
Imports IronPdf
Imports System
Friend Class Program
	Shared Sub Main(ByVal args() As String)
		License.LicenseKey = "License-Key"
		'  Inicializar el valor
		Dim totalSales As Integer = 150
		'  Modificar el valor dentro del método utilizando 'ref'.
		AddMonthlyBonus(totalSales)
		'  Utilice IronPDF para generar un informe en PDF
		Dim Renderer = New ChromePdfRenderer()
		Dim PDF = Renderer.RenderHtmlAsPdf($"<h1>Monthly Sales Report</h1><p>Total Sales, including bonus: {totalSales}</p>")
		'  Guardar el PDF en un archivo
		PDF.SaveAs("MonthlySalesReport.pdf")
		'  Confirmar que se ha generado el PDF
		Console.WriteLine("PDF generated successfully. Check your project directory.")
	End Sub
	Private Shared Sub AddMonthlyBonus(ByRef sales As Integer)
		'  Supongamos una bonificación del 10% de las ventas
		sales += CInt(Math.Truncate(sales * 0.1))
	End Sub
End Class
VB   C#

C# Ref (Cómo funciona para desarrolladores): Figura 2

En este ejemplo, VentasTotales comienza en 150. El método AddMonthlyBonus toma este valor como referencia utilizando la palabra clave ref, calcula una bonificación del 10% y la añade al valor original de las ventas. IronPDF genera entonces un documento PDF que contiene un fragmento HTML que informa de las ventas totales, incluida la bonificación. El documento final se guarda localmente como "MonthlySalesReport.pdf".

Conclusión

C# Ref (Cómo funciona para desarrolladores): Figura 3

Entender la palabra clave ref en C# proporciona una valiosa herramienta para gestionar cómo se pasan los datos entre métodos. Al permitir que los métodos modifiquen directamente los valores originales de los parámetros que se les pasan, ref puede hacer que tus métodos sean más flexibles y potentes.

A medida que adquiera experiencia con ref, comprenderá mejor cuándo y cómo utilizarlo eficazmente para satisfacer sus necesidades de programación. IronPDF ofrece un prueba gratuita a partir de 749 dólares.

< ANTERIOR
MS Graph .NET (Cómo funciona para desarrolladores)
SIGUIENTE >
Mudblazor .NET 8 (Cómo funciona para los desarrolladores)

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

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