Cola de bloqueo de Java
Cola de bloqueo de Java
En este tutorial, aprenderemos sobre la interfaz Java BlockingQueue y sus métodos.
El BlockingQueue
interfaz de Java Collections
framework extiende el Queue
interfaz. Permite que cualquier operación espere hasta que se pueda realizar con éxito.
Por ejemplo, si queremos eliminar un elemento de una cola vacía, entonces la cola de bloqueo permite que la operación de eliminación espere hasta que la cola contenga algunos elementos para eliminar.
Clases que implementan BlockingQueue
Desde BlockingQueue
es una interfaz, no podemos proporcionar la implementación directa de la misma.
Para utilizar la funcionalidad del BlockingQueue
, necesitamos usar clases que lo implementen.
- Cola de bloqueo de matrices
- Cola de bloqueo enlazada
¿Cómo usar colas de bloqueo?
Debemos importar el java.util.concurrent.BlockingQueue
paquete para usar BlockingQueue
.
// Array implementation of BlockingQueue
BlockingQueue<String> animal1 = new ArraryBlockingQueue<>();
// LinkedList implementation of BlockingQueue
BlockingQueue<String> animal2 = new LinkedBlockingQueue<>();
Aquí, hemos creado objetos animal1 y animal2 de clases ArrayBlockingQueue
y LinkedBlockingQueue
, respectivamente. Estos objetos pueden usar las funcionalidades del BlockingQueue
interfaz.
Métodos de BlockingQueue
Según si una cola está llena o vacía, los métodos de una cola de bloqueo se pueden dividir en 3 categorías:
Métodos que lanzan una excepción
add()
- Inserta un elemento en la cola de bloqueo al final de la cola. Lanza una excepción si la cola está llena.element()
- Devuelve la cabeza de la cola de bloqueo. Lanza una excepción si la cola está vacía.remove()
- Elimina un elemento de la cola de bloqueo. Lanza una excepción si la cola está vacía.
Métodos que devuelven algún valor
offer()
- Inserta el elemento especificado en la cola de bloqueo al final de la cola. Devuelvefalse
si la cola está llena.peek()
- Devuelve la cabeza de la cola de bloqueo. Devuelvenull
si la cola está vacía.poll()
- Elimina un elemento de la cola de bloqueo. Devuelvenull
si la cola está vacía.
Más en oferta() y encuesta()
El offer()
y poll()
El método se puede utilizar con tiempos de espera. Es decir, podemos pasar unidades de tiempo como parámetro. Por ejemplo,
offer(value, 100, milliseconds)
Aquí,
- valor es el elemento que se insertará en la cola
- Y hemos establecido un tiempo de espera de 100 milisegundos
Esto significa el offer()
El método intentará insertar un elemento en la cola de bloqueo para 100
milisegundos. Si el elemento no se puede insertar en 100 milisegundos, el método devuelve false
.
milliseconds
, también podemos usar estas unidades de tiempo:days
, hours
, minutes
, seconds
, microseconds
y nanoseconds
en offer()
y poll()
métodos.
Métodos que bloquean la operación
El BlockingQueue
también proporciona métodos para bloquear las operaciones y esperar si la cola está llena o vacía.
put()
- Inserta un elemento a la cola de bloqueo. Si la cola está llena, esperará hasta que tenga espacio para insertar un elemento.take()
- Elimina y devuelve un elemento de la cola de bloqueo. Si la cola está vacía, esperará hasta que la cola tenga elementos para eliminar.
Supongamos que queremos insertar elementos en una cola. Si la cola está llena, el put()
esperará hasta que la cola tenga espacio para insertar elementos.
Del mismo modo, si queremos eliminar elementos de una cola. Si la cola está vacía entonces el take()
esperará hasta que la cola contenga elementos para eliminar.
Implementación de BlockingQueue en ArrayBlockingQueue
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.ArrayBlockingQueue;
class Main {
public static void main(String[] args) {
// Create a blocking queue using the ArrayBlockingQueue
BlockingQueue<Integer> numbers = new ArrayBlockingQueue<>(5);
try {
// Insert element to blocking queue
numbers.put(2);
numbers.put(1);
numbers.put(3);
System.out.println("BLockingQueue: " + numbers);
// Remove Elements from blocking queue
int removedNumber = numbers.take();
System.out.println("Removed Number: " + removedNumber);
}
catch(Exception e) {
e.getStackTrace();
}
}
}
Salida
BlockingQueue: [2, 1, 3] Removed Element: 2
Para obtener más información sobre ArrayBlockingQueue
, visite Java ArrayBlockingQueue.
¿Por qué BlockingQueue?
En Java, BlockingQueue
se considera como seguro para subprocesos recopilación. Es porque puede ser útil en operaciones de subprocesos múltiples.
Supongamos que un subproceso está insertando elementos en la cola y otro subproceso está eliminando elementos de la cola.
Ahora, si el primer subproceso se ejecuta más lento, entonces la cola de bloqueo puede hacer que el segundo subproceso espere hasta que el primer subproceso complete su operación.
Java