AYUDA .NET

C# Queue (Cómo funciona para desarrolladores)

Publicado en 4 de enero, 2024
Compartir:

1. Introducción

En el ámbito de la programación, el tratamiento eficaz de los datos es la piedra angular del éxito en el desarrollo de software. Una estructura de datos esencial que desempeña un papel crucial en la gestión y organización de la información es la cola. En el contexto de C#, un lenguaje de programación potente y versátil, la cola de C# destaca como una herramienta fundamental para gestionar datos de forma secuencial. Para saber más sobre las Colas en C# aquí están los artículos recomendados aquí y aquí.

Una cola sigue el principio de "primero en entrar, primero en salir (FIFO) donde el primer elemento que se añade es el primero que se elimina. Esta característica lo hace especialmente útil en escenarios en los que es necesario procesar datos u objetos en un orden específico, como la gestión de tareas de forma sistemática o la gestión de peticiones en un servidor web.

En este artículo vamos a utilizar C# PDF Library IronPDF con la cola de C#.

2. Tipos y usos de C# Cola de espera

2.1. Cola estándar

La cola estándar en C# es una clase genérica que permite a los desarrolladores crear una cola de cualquier tipo de datos. Proporciona métodos como Enqueue para añadir elementos al objeto especificado al principio o al final de la cola y Dequeue para eliminar elementos del frente. Este tipo de cola se utiliza ampliamente en escenarios en los que el procesamiento de datos sigue un orden estricto, garantizando la equidad en la asignación de recursos.

using System;
using System.Collections.Generic;
class Program
{
    static void Main()
    {   // create an empty queue
        Queue<int> standardQueue = new Queue<int>();
        standardQueue.Enqueue(10);
        standardQueue.Enqueue(20);
        standardQueue.Enqueue(30);
        while (standardQueue.Count > 0)
        {
            int element = standardQueue.Dequeue();
            Console.WriteLine($"Dequeued: {element}");
        }}}
using System;
using System.Collections.Generic;
class Program
{
    static void Main()
    {   // create an empty queue
        Queue<int> standardQueue = new Queue<int>();
        standardQueue.Enqueue(10);
        standardQueue.Enqueue(20);
        standardQueue.Enqueue(30);
        while (standardQueue.Count > 0)
        {
            int element = standardQueue.Dequeue();
            Console.WriteLine($"Dequeued: {element}");
        }}}
Imports System
Imports System.Collections.Generic
Friend Class Program
	Shared Sub Main() ' create an empty queue
		Dim standardQueue As New Queue(Of Integer)()
		standardQueue.Enqueue(10)
		standardQueue.Enqueue(20)
		standardQueue.Enqueue(30)
		Do While standardQueue.Count > 0
			Dim element As Integer = standardQueue.Dequeue()
			Console.WriteLine($"Dequeued: {element}")
		Loop
	End Sub
End Class
VB   C#

Salida

Cola C# (Cómo funciona para los desarrolladores): Figura 1 - SALIDA: Cola estándar

2.2. Cola prioritaria

En determinadas situaciones, la priorización de elementos en la cola resulta crucial. C# no tiene una cola de prioridad incorporada, pero los desarrolladores pueden implementarla utilizando una colección ordenada o una estructura de datos personalizada. Este tipo de cola es beneficioso cuando determinados elementos deben procesarse antes que otros en función de criterios específicos, como la urgencia o la importancia. Comprueba si el elemento existe y utiliza el estilo FIFO para disponer el elemento más antiguo al final de la cola, también determina si un elemento debe ser el principio de la cola en función del número de elementos que contenga.

using System;
using System.Collections.Generic;
class Program
{    static void Main()
    {
        SortedSet<int> priorityQueue = new SortedSet<int>();
        priorityQueue.Add(30);
        priorityQueue.Add(10);
        priorityQueue.Add(20);
        while (priorityQueue.Count > 0)
        {
            int element = priorityQueue.Min;
            priorityQueue.Remove(element);
            Console.WriteLine($"Priority Queue Dequeued: {element}");
        }
    }
}
using System;
using System.Collections.Generic;
class Program
{    static void Main()
    {
        SortedSet<int> priorityQueue = new SortedSet<int>();
        priorityQueue.Add(30);
        priorityQueue.Add(10);
        priorityQueue.Add(20);
        while (priorityQueue.Count > 0)
        {
            int element = priorityQueue.Min;
            priorityQueue.Remove(element);
            Console.WriteLine($"Priority Queue Dequeued: {element}");
        }
    }
}
Imports System
Imports System.Collections.Generic
Friend Class Program
	Shared Sub Main()
		Dim priorityQueue As New SortedSet(Of Integer)()
		priorityQueue.Add(30)
		priorityQueue.Add(10)
		priorityQueue.Add(20)
		Do While priorityQueue.Count > 0
			Dim element As Integer = AddressOf priorityQueue.Min
			priorityQueue.Remove(element)
			Console.WriteLine($"Priority Queue Dequeued: {element}")
		Loop
	End Sub
End Class
VB   C#

Cola C# (Cómo funciona para los desarrolladores): Figura 2 - SALIDA: Cola prioritaria

2.3. Cola circular

Una cola circular es una variante en la que el último elemento está conectado al primero, creando una estructura circular. Esto puede ser ventajoso en escenarios en los que la cola tiene un tamaño fijo, y los elementos antiguos de la cola deben ser sustituidos por otros nuevos de forma cíclica. La implementación de una cola circular en C# puede optimizar el uso de la memoria y garantizar un procesamiento eficaz de los datos.

using System;
// Queue class
class CircularQueue
{
    private int [] array;
    private int front, rear, size;
    public CircularQueue(int size)
    {
        this.size = size;
        array = new int [size];
        front = rear = -1;
    }
    // enqueue method
    public void Enqueue(int item)
    {
        if ((front == 0 && rear == size - 1) 
 (rear == (front - 1) % (size - 1)))
        {
            Console.WriteLine("Queue is full");
            return;
        }
        else if (front == -1)
        {
            front = rear = 0;
            array [rear] = item;
        }
        else if (rear == size - 1 && front != 0)
        {
            rear = 0;
            array [rear] = item;
        }
        else
        {
            rear++;
            array [rear] = item;
        }
    }
    public int Dequeue()
    {
        if (front == -1)
        {
            Console.WriteLine("Queue is empty");
            return -1;
        }
        int item = array [front];
        array [front] = -1;
        if (front == rear)
            front = rear = -1;
        else if (front == size - 1)
            front = 0;
        else
            front++;
        return item;
    }
}
class Program
{
    static void Main()
    {   // specified initial capacity 5
        CircularQueue circularQueue = new CircularQueue(5);
        circularQueue.Enqueue(10);
        circularQueue.Enqueue(20);
        circularQueue.Enqueue(30);
        Console.WriteLine($"Circular Queue Dequeued: {circularQueue.Dequeue()}");
        Console.WriteLine($"Circular Queue Dequeued: {circularQueue.Dequeue()}");
    }
}
using System;
// Queue class
class CircularQueue
{
    private int [] array;
    private int front, rear, size;
    public CircularQueue(int size)
    {
        this.size = size;
        array = new int [size];
        front = rear = -1;
    }
    // enqueue method
    public void Enqueue(int item)
    {
        if ((front == 0 && rear == size - 1) 
 (rear == (front - 1) % (size - 1)))
        {
            Console.WriteLine("Queue is full");
            return;
        }
        else if (front == -1)
        {
            front = rear = 0;
            array [rear] = item;
        }
        else if (rear == size - 1 && front != 0)
        {
            rear = 0;
            array [rear] = item;
        }
        else
        {
            rear++;
            array [rear] = item;
        }
    }
    public int Dequeue()
    {
        if (front == -1)
        {
            Console.WriteLine("Queue is empty");
            return -1;
        }
        int item = array [front];
        array [front] = -1;
        if (front == rear)
            front = rear = -1;
        else if (front == size - 1)
            front = 0;
        else
            front++;
        return item;
    }
}
class Program
{
    static void Main()
    {   // specified initial capacity 5
        CircularQueue circularQueue = new CircularQueue(5);
        circularQueue.Enqueue(10);
        circularQueue.Enqueue(20);
        circularQueue.Enqueue(30);
        Console.WriteLine($"Circular Queue Dequeued: {circularQueue.Dequeue()}");
        Console.WriteLine($"Circular Queue Dequeued: {circularQueue.Dequeue()}");
    }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

Cola C# (Cómo funciona para los desarrolladores): Figura 3 - SALIDA: Cola circular

3. Presentación de IronPDF en C#

A medida que nos adentramos en las funcionalidades y aplicaciones de la cola de C#, es esencial explorar cómo puede integrarse perfectamente en aplicaciones del mundo real. Una de estas potentes herramientas que mejora las capacidades de C# es IronPDF.

IronPDF es una biblioteca C# que simplifica la creación, manipulación y representación de documentos PDF. Su intuitiva API permite a los desarrolladores generar PDF a partir de HTML, ASPX o incluso texto sin formato. Con IronPDF, el proceso de incorporación de C# Queue a una aplicación generadora de PDF se vuelve más ágil y eficaz.

3.1. Uso de C# Cola con código IronPDF

Echemos un vistazo más de cerca a cómo se puede utilizar C# Queue junto con IronPDF para crear documentos PDF dinámicos y organizados. Consideremos un escenario en el que una aplicación web necesita generar un informe PDF basado en las entradas y peticiones del usuario.

using IronPdf;
using System;
using System.Collections.Generic;
class PdfGenerator
{
    static void Main()
    {
        // Create a C# Queue to store user requests
        Queue<string> userRequests = new Queue<string>();
        // Simulate user requests being added to the queue
        userRequests.Enqueue("Generate PDF for User 1");
        userRequests.Enqueue("Generate PDF for User 2");
        userRequests.Enqueue("Generate PDF for User 3");
        // Process requests and generate PDFs
        while (userRequests.Count > 0)
        {
            string request = userRequests.Dequeue();
            GeneratePdf(request);
        }
    }
    static void GeneratePdf(string userRequest)
    {
        // Use IronPDF to generate PDF based on user request
        var Renderer = new HtmlToPdf();
        var PDF = Renderer.RenderHtmlAsPdf($"<h1>{userRequest}</h1>");
        // Save the generated PDF
        PDF.SaveAs($"{userRequest.Replace(" ", "_")}.pdf");
    }
}
using IronPdf;
using System;
using System.Collections.Generic;
class PdfGenerator
{
    static void Main()
    {
        // Create a C# Queue to store user requests
        Queue<string> userRequests = new Queue<string>();
        // Simulate user requests being added to the queue
        userRequests.Enqueue("Generate PDF for User 1");
        userRequests.Enqueue("Generate PDF for User 2");
        userRequests.Enqueue("Generate PDF for User 3");
        // Process requests and generate PDFs
        while (userRequests.Count > 0)
        {
            string request = userRequests.Dequeue();
            GeneratePdf(request);
        }
    }
    static void GeneratePdf(string userRequest)
    {
        // Use IronPDF to generate PDF based on user request
        var Renderer = new HtmlToPdf();
        var PDF = Renderer.RenderHtmlAsPdf($"<h1>{userRequest}</h1>");
        // Save the generated PDF
        PDF.SaveAs($"{userRequest.Replace(" ", "_")}.pdf");
    }
}
Imports IronPdf
Imports System
Imports System.Collections.Generic
Friend Class PdfGenerator
	Shared Sub Main()
		' Create a C# Queue to store user requests
		Dim userRequests As New Queue(Of String)()
		' Simulate user requests being added to the queue
		userRequests.Enqueue("Generate PDF for User 1")
		userRequests.Enqueue("Generate PDF for User 2")
		userRequests.Enqueue("Generate PDF for User 3")
		' Process requests and generate PDFs
		Do While userRequests.Count > 0
			Dim request As String = userRequests.Dequeue()
			GeneratePdf(request)
		Loop
	End Sub
	Private Shared Sub GeneratePdf(ByVal userRequest As String)
		' Use IronPDF to generate PDF based on user request
		Dim Renderer = New HtmlToPdf()
		Dim PDF = Renderer.RenderHtmlAsPdf($"<h1>{userRequest}</h1>")
		' Save the generated PDF
		PDF.SaveAs($"{userRequest.Replace(" ", "_")}.pdf")
	End Sub
End Class
VB   C#

En este ejemplo, una cola C (userRequests) devuelve el objeto utilizado para almacenar las solicitudes de usuario para la generación de PDF. El método GeneratePdf toma una petición del usuario, utiliza IronPDF para convertir el contenido HTML en un documento PDF, y guarda el archivo PDF generado con un nombre relevante.

Este método de integración también muestra la sinergia entre C# Queue e IronPDF, donde el procesamiento ordenado de las solicitudes de los usuarios da como resultado la creación sistemática de documentos PDF.

3.2. Salida # 1

Cola C# (Cómo funciona para los desarrolladores): Figura 4 - SALIDA 1: Generar PDF utilizando IronPDF y C# Queue

3.3. Salida # 2

Cola C# (Cómo funciona para los desarrolladores): Figura 5 - SALIDA 2: Generar PDF utilizando IronPDF y C# Queue

3.4. Salida # 3

Cola C# (Cómo funciona para los desarrolladores): Figura 6 - SALIDA 3: Generar PDF utilizando IronPDF y C# Queue

4. Conclusión

En conclusión, la cola de C# demuestra ser un activo valioso para gestionar y procesar datos de forma secuencial. Su adhesión al principio FIFO lo hace adecuado para una amplia gama de aplicaciones, desde la programación de tareas a la gestión de peticiones en servidores web. Cuando se combina con potentes bibliotecas como IronPDFC# Queue se vuelve aún más potente, permitiendo a los desarrolladores crear documentos PDF organizados y dinámicos de forma eficaz.

Comprender los matices de C# Queue y explorar su integración con herramientas como IronPDF permite a los desarrolladores diseñar soluciones sólidas y eficaces para la gestión y el procesamiento de datos. A medida que la tecnología siga evolucionando, la sinergia entre estructuras de datos fundamentales como la cola de C# y bibliotecas innovadoras desempeñará un papel fundamental en la configuración del panorama del desarrollo de software.

IronPDF. Para obtener más información sobre la conversión de HTML a PDF, visite la siguiente página web enlace.

< ANTERIOR
Hangfire .NET Core (Cómo Funciona para Desarrolladores)
SIGUIENTE >
C# Case Statement (Cómo funciona para los desarrolladores)

¿Listo para empezar? Versión: 2024.10 acaba de salir

Descarga gratuita de NuGet Descargas totales: 11,173,334 Ver licencias >