.NET-HILFE

C# Warteschlange (Wie es für Entwickler funktioniert)

Veröffentlicht 4. Januar 2024
Teilen Sie:

1. Einführung

Im Bereich der Programmierung ist die effiziente Datenverarbeitung ein Eckpfeiler der erfolgreichen Softwareentwicklung. Eine wichtige Datenstruktur, die eine entscheidende Rolle bei der Verwaltung und Organisation von Informationen spielt, ist die Warteschlange. Im Kontext von C#, einer leistungsstarken und vielseitigen Programmiersprache, sticht die C#-Warteschlange als grundlegendes Werkzeug für die sequentielle Verwaltung von Daten hervor. Um mehr über die Warteschlangen in C# zu erfahren, finden Sie hier die empfohlenen Artikel überWarteschlangen in C# undGenerische Warteschlangenklasse in .NET.

Eine Warteschlange folgt dem Prinzip First-In-First-Out(FIFO) prinzip, bei dem das erste hinzugefügte Element auch das erste zu entfernende Element ist. Diese Eigenschaft macht sie besonders nützlich in Szenarien, in denen Daten oder Objekte in einer bestimmten Reihenfolge verarbeitet werden müssen, z. B. bei der systematischen Bearbeitung von Aufgaben oder der Verwaltung von Anfragen in einem Webserver.

In diesem Artikel werden wir die C# PDF Library verwendenIronPDF mit der C#-Warteschlange.

2. Arten und Verwendungen von C# Queue

2.1. Standard-Warteschlange

Die Standard-Warteschlange in C# ist eine generische Klasse, die es Entwicklern ermöglicht, eine Warteschlange für einen beliebigen Datentyp zu erstellen. Sie bietet Methoden wie "Enqueue" zum Hinzufügen von Elementen zum angegebenen Objekt am Anfang oder Ende der Warteschlange und "Dequeue" zum Entfernen von Elementen von der Spitze. Diese Art von Warteschlange wird häufig in Szenarien verwendet, in denen die Datenverarbeitung in einer strengen Reihenfolge erfolgt, um eine faire Ressourcenzuweisung zu gewährleisten.

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#

Ausgabe

C#-Warteschlange (So funktioniert es für Entwickler): Abbildung 1 - OUTPUT: Standard-Warteschlange

2.2. Vorrangige Warteschlange

In bestimmten Situationen ist die Priorisierung von Elementen in der Warteschlange entscheidend. C# verfügt nicht über eine eingebaute Prioritätswarteschlange, aber Entwickler können eine solche implementieren, indem sie eine sortierte Auflistung oder eine benutzerdefinierte Datenstruktur verwenden. Diese Art von Warteschlange ist von Vorteil, wenn bestimmte Elemente aufgrund bestimmter Kriterien wie Dringlichkeit oder Wichtigkeit vor anderen verarbeitet werden müssen. Es prüft, ob das Element vorhanden ist, und ordnet das älteste Element nach dem FIFO-Prinzip an das Ende der Warteschlange an. Außerdem wird anhand der Anzahl der enthaltenen Elemente bestimmt, ob ein Element am Anfang der Warteschlange stehen sollte.

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#

C#-Warteschlange (So funktioniert es für Entwickler): Abbildung 2 - OUTPUT: Prioritäts-Warteschlange

2.3. Kreisförmige Warteschlange

Eine kreisförmige Warteschlange ist eine Variante, bei der das letzte Element mit dem ersten verbunden ist, wodurch eine kreisförmige Struktur entsteht. Dies kann in Szenarien von Vorteil sein, in denen die Warteschlange eine feste Größe hat und alte Warteschlangenelemente zyklisch durch neue ersetzt werden müssen. Durch die Implementierung einer zirkulären Warteschlange in C# kann die Speichernutzung optimiert und eine effiziente Datenverarbeitung gewährleistet werden.

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()}");
    }
}
Imports System
' Queue class
Friend Class CircularQueue
	Private array() As Integer
	Private front, rear, size As Integer
	Public Sub New(ByVal size As Integer)
		Me.size = size
		array = New Integer(size - 1){}
'INSTANT VB WARNING: An assignment within expression was extracted from the following statement:
'ORIGINAL LINE: front = rear = -1;
		rear = -1
		front = rear
	End Sub

	' enqueue method
	Public Sub Enqueue(ByVal item As Integer)
		If (front = 0 AndAlso rear = size - 1)(rear = (front - 1) Mod (size - 1)) Then
			Console.WriteLine("Queue is full")
			Return
		ElseIf front = -1 Then
'INSTANT VB WARNING: An assignment within expression was extracted from the following statement:
'ORIGINAL LINE: front = rear = 0;
			rear = 0
			front = rear
			array(rear) = item
		ElseIf rear = size - 1 AndAlso front <> 0 Then
			rear = 0
			array(rear) = item
		Else
			rear += 1
			array(rear) = item
		End If
	End Sub
	Public Function Dequeue() As Integer
		If front = -1 Then
			Console.WriteLine("Queue is empty")
			Return -1
		End If
		Dim item As Integer = array(front)
		array(front) = -1
		If front = rear Then
'INSTANT VB WARNING: An assignment within expression was extracted from the following statement:
'ORIGINAL LINE: front = rear = -1;
			rear = -1
			front = rear
		ElseIf front = size - 1 Then
			front = 0
		Else
			front += 1
		End If
		Return item
	End Function
End Class
Friend Class Program
	Shared Sub Main()
		' specified initial capacity 5
		Dim circularQueue As 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()}")
	End Sub
End Class
VB   C#

C#-Warteschlange (So funktioniert es für Entwickler): Abbildung 3 - OUTPUT: Kreisförmige Warteschlange

3. Einführung in IronPDF in C#

Während wir uns mit den Funktionalitäten und Anwendungen der C# Queue beschäftigen, ist es wichtig zu untersuchen, wie sie nahtlos in reale Anwendungen integriert werden kann. Ein solches leistungsfähiges Tool, das die C#-Fähigkeiten erweitert, ist IronPDF.

IronPDF ist eine C#-Bibliothek, die die Erstellung, Bearbeitung und Darstellung von PDF-Dokumenten vereinfacht. Die intuitive API ermöglicht es Entwicklern, PDFs aus HTML, ASPX oder sogar einfachem Text zu erzeugen. Mit IronPDF wird der Prozess der Einbindung von C# Queue in eine PDF-erzeugende Anwendung rationalisiert und effizient.

3.1. Verwendung von C# Queue mit IronPDF Code

Schauen wir uns genauer an, wie die C# Queue in Verbindung mit IronPDF genutzt werden kann, um dynamische und organisierte PDF-Dokumente zu erstellen. Stellen Sie sich ein Szenario vor, in dem eine Webanwendung einen PDF-Bericht auf der Grundlage von Benutzereingaben und -anforderungen erstellen muss.

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#

In diesem Beispiel wird eine C#-Warteschlange(userRequests) wird verwendet, um Benutzeranfragen für die PDF-Erstellung zu speichern. Die Methode GeneratePdf nimmt eine Benutzeranfrage entgegen, verwendet IronPDF, um HTML-Inhalte in ein PDF-Dokument zu konvertieren, und speichert die erzeugte PDF-Datei unter einem entsprechenden Namen.

Diese Integrationsmethode verdeutlicht auch die Synergie zwischen C# Queue und IronPDF, bei der die geordnete Verarbeitung von Benutzeranfragen zur systematischen Erstellung von PDF-Dokumenten führt.

3.2. Ausgabe #1

C# Warteschlange(Wie es für Entwickler funktioniert): Abbildung 4 - OUTPUT 1: Erzeugen von PDF mit IronPDF und C# Queue

3.3. Ausgabe #2

C# Warteschlange(Funktionsweise für Entwickler): Abbildung 5 - AUSGABE 2: Erzeugen von PDF mit IronPDF und C# Queue

3.4. Ausgabe #3

C# Warteschlange(Wie es für Entwickler funktioniert): Abbildung 6 - OUTPUT 3: Erzeugen von PDF mit IronPDF und C# Queue

4. Schlussfolgerung

Zusammenfassend lässt sich sagen, dass die C#-Warteschlange ein wertvolles Hilfsmittel für die sequentielle Verwaltung und Verarbeitung von Daten ist. Durch die Einhaltung des FIFO-Prinzips eignet es sich für eine breite Palette von Anwendungen, von der Aufgabenplanung bis zur Bearbeitung von Anfragen in Webservern. In Kombination mit leistungsfähigen Bibliotheken wieIronPDFwird die C#-Warteschlange noch leistungsfähiger und ermöglicht es Entwicklern, organisierte und dynamische PDF-Dokumente effizient zu erstellen.

Das Verständnis der Nuancen von C# Queue und die Erforschung seiner Integration mit Tools wie IronPDF ermöglicht es Entwicklern, robuste und effiziente Lösungen für die Datenverwaltung und -verarbeitung zu entwerfen. Im Zuge der weiteren technologischen Entwicklung wird die Synergie zwischen grundlegenden Datenstrukturen wie der C# Queue und innovativen Bibliotheken eine entscheidende Rolle bei der Gestaltung der Software-Entwicklungslandschaft spielen.

Informationen zur Lizenzierung finden Sie unterIronPDF-Lizenzierungsdetails. Um mehr über die Konvertierung von HTML in PDF zu erfahren, besuchen Sie dieTutorial zur Konvertierung von HTML in PDF.

< PREVIOUS
Hangfire .NET Core (Wie es für Entwickler funktioniert)
NÄCHSTES >
C# Case-Anweisung (Wie es funktioniert für Entwickler)

Sind Sie bereit, loszulegen? Version: 2024.12 gerade veröffentlicht

Gratis NuGet-Download Downloads insgesamt: 11,810,873 Lizenzen anzeigen >