La structure des données de la file d'attente utilise le principe First In First Out (FIFO). Il permet de conserver les objets à traiter dans l'ordre de leur arrivée ; cela ressemble beaucoup à la file de personnes faisant la queue. Comme Java fournit une large prise en charge de la structure des données sous la forme de l'interface Collection, la file d'attente est une interface disponible dans l'interface Collection. Il étend l'interface Collection. Il est disponible dans le package Java.util et prend en charge toutes les opérations disponibles dans l'interface Collection, ainsi que certaines opérations supplémentaires d'extraction, d'insertion et d'inspection.
Commencez votre cours de développement de logiciels libres
Développement Web, langages de programmation, tests de logiciels et autres
Syntaxe :
Interface Queue<E>
La file d'attente est une interface, pas une classe, elle ne peut donc pas être instanciée directement. La déclaration montre que la file d'attente accepte les valeurs comme génériques similaires aux collections, et nous pouvons lui transmettre n'importe quel objet. Java a plusieurs implémentations de l'interface Queue, que nous pouvons utiliser lors de l'utilisation des files d'attente. Ce sont LinkedList et PriorityQueue.
Une file d'attente peut être déclarée comme ci-dessous :
Queue< Object > q = new LinkedList<>();
Queue< Object > q = new PriorityQueue<>();
Types de membres de file d'attente en Java
Vous trouverez ci-dessous toutes les méthodes disponibles dans la file d'attente :
Returns special value | Throws exception | |
Insert | offer(e) | add(e) |
Remove | poll() | remove() |
Examine | peek() | element() |
So as explained, two types of methods throw an exception and return a special value. There are three types of operation in this kind of operation: insertion, the second is removal, and the third is retrieval or examination. In the case of the remove operation, an object will be removed from the queue. Still, in the case of examination, the object will be returned without actually removing from the queue.
Given below are the different examples of Queue in Java:
Code:
import java.util.LinkedList; import java.util.Queue; public class QueueOperations { public static void main(String[] args) { Queue<Integer> q = new LinkedList<Integer> (); q.add(5); q.add(2); q.add(1); q.add(4); q.add(3); System.out.println(q); } }
Output:
Note here that the order of insertion is the same with output from left to write.
Code:
import java.util.LinkedList; import java.util.Queue; public class QueueOperations { public static void main(String[] args) { Queue<Integer> q = new LinkedList<Integer> (); q.add(5); q.add(2); q.add(1); q.add(4); q.add(3); System.out.println(q); while (!q.isEmpty()) { System.out.print(q.remove() + " "); } System.out.println(""); System.out.println(q); } }
Output:
Here, we have used the function isEmpty() to check when the queue becomes empty after removing elements. The removal order is the same as per the insertion. After removing all the elements, we printed the queue and obtained an empty bracket at the end.
Code:
import java.util.PriorityQueue; import java.util.Queue; public class QueueOperations { public static void main(String[] args) { Queue<Integer> q = new PriorityQueue<Integer> (); q.add(5); q.add(2); q.add(1); q.add(4); q.add(3); System.out.println(q); while (!q.isEmpty()) { System.out.print(q.remove() + " "); } System.out.println(""); System.out.println(q); } }
Output:
Here, we have used PriorityQueue, which will hold and return the elements depending upon the elements’ natural ordering or upon the comparator, if any passed. Note the insertion order and removal orders are not the same. The removal is based totally on the value of elements.
Code:
import java.util.LinkedList; import java.util.Queue; public class QueueOperations { public static void main(String[] args) { Queue<Integer> q = new LinkedList<Integer> (); q.add(5); q.add(2); q.add(1); q.add(4); q.add(3); System.out.println(q); System.out.println( q.peek() ); System.out.println(q); } }
Output:
Note here that we have used the peek() function, which will return the head of the queue without actually removing it. We printed the queue after performing the peek operation, and you can observe that the head element, which is 5, remains unchanged in the queue.
Code:
import java.util.PriorityQueue; import java.util.Queue; public class QueueOperations { public static void main(String[] args) { Queue<Integer> q = new PriorityQueue<Integer> (); q.add(5); q.add(2); q.add(1); q.add(4); q.add(3); System.out.println(q); System.out.println( q.peek() ); System.out.println(q); } }
Output:
This is similar to the previous example’s LinkedList operation, but note the head element is 1 because it’s a PriorityQueue.
Java utilizes the Queue interface as a means to maintain elements in insertion order. It supports operations like insertion, retrieval, and removal. There are alternative methods available for all the methods. We have seen examples of the most commonly used methods in queue operation.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!