Utilizando la Interfaz Java Deque.
La interfaz Java Deque java.util.Deque, representa una cola de doble extremo, lo que significa una cola donde puede agregar y eliminar elementos de ambos extremos de la cola. El nombre Deque es una abreviatura de Double Ended Queue.
Para implementar un Deque podemos utilizar dos interfaces, por una parte java.util.LinkedList el más estándar y java.util.ArrayDeque.
La interfaz Java Deque contiene los siguientes métodos para agregarle elementos:
- add(): Agregar elemento al principio de la cola.
- addLast (): Agrega un elemento al final de la cola.
- addFirst (): Agrega un elemento al principio de la cola.
Para eliminar elementos de un Java Deque, puede usarse uno de los siguientes métodos:
- remove(): Elimina el primer elemento.
- removeFirst(): Remueve el primer elemento.
- removeLast(): Remueve el ultimo elemento.
Como ejemplo utilizamos la clase “Usuario” que nos sirve para almacenar como registro, una clase “UsuarioApp” con el método main para la ejecución.
Clase Usuario./** * * @author carlos */ public class Usuario { //Atributos private int id; private String nombre; private String password; //Constructores public Usuario() { } public Usuario(int id, String nombre, String password) { this.id = id; this.nombre = nombre; this.password = password; } //Getters y Setters public int getId() { return id; } public void setId(int id) { this.id = id; } public String getNombre() { return nombre; } public void setNombre(String nombre) { this.nombre = nombre; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } }Clase UsuarioApp
import java.util.Deque; import java.util.LinkedList; /** * * @author carlos */ public class DequeApp { /** * @param args the command line arguments */ public static void main(String[] args) { //Métodos creados más abajo Deque<Usuario> usuario = cargar(); print(usuario); eliminar(usuario); print(usuario); } static Deque<Usuario> cargar(){ //Forma de instanciar un Deque utilizando LinkedList Deque<Usuario> us = new LinkedList<>(); //add() agrega elementos al princio. En orden en que llega. us.add(new Usuario(1, "Angel", "sng1236")); us.add(new Usuario(2, "Perla", "per20145")); //addFirst() agrega justo al principio de la lista us.addFirst(new Usuario(3, "Manuela", "mnd23145")); //addLast() agrega elemento al final de la lista us.addLast(new Usuario(4, "Luis", "lu2345")); return us; } static void eliminar(Deque<Usuario> usuario){ System.out.println("----------------------"); System.out.println("Removiendo elementos"); //Remueve el primer elemento usuario.removeFirst(); //Remueve el último elemento. usuario.removeLast(); } static void print(Deque<Usuario> usuario){ System.out.println("Imprimiendo Datos."); for(Usuario us : usuario){ System.out.println("______________________________"); System.out.println("ID: " + us.getId()); System.out.println("Nombre: " + us.getNombre()); System.out.println("Password: " + us.getPassword()); } } }Resultado.
No hay comentarios:
Publicar un comentario