En este tutorial, aprenderemos sobre la clase Java EnumMap y sus operaciones con la ayuda de ejemplos.

La
EnumMap
clase del marco de colecciones de Java proporciona una implementación de mapa para elementos de una enumeración.
En
EnumMap
, los elementos de enumeración se utilizan como claves . Implementa la interfaz del mapa .
Antes de aprender acerca de
EnumMap
, asegúrese de saber sobre las enumeraciones de Java .Creando un EnumMap
Para crear un mapa de enumeración,
java.util.EnumMap
primero debemos importar el paquete. Una vez que importamos el paquete, así es como podemos crear mapas de enumeración en Java.
enum Size {
SMALL, MEDIUM, LARGE, EXTRALARGE
}
EnumMap<Size, Integer> sizes = new EnumMap<>(Size.class);
En el ejemplo anterior, hemos creado un mapa de enumeración llamado tamaños .
Aquí,
- Tamaño : claves de la enumeración que se asignan a valores
- Entero : valores del mapa de enumeración asociados con las claves correspondientes
Métodos de EnumMap
La
EnumMap
clase proporciona métodos que nos permiten realizar varios elementos en los mapas de enumeración.Insertar elementos en EnumMap
put()
- inserta el mapeo clave / valor especificado (entrada) en el mapa enumputAll()
- inserta todas las entradas de un mapa especificado en este mapa
Por ejemplo,
import java.util.EnumMap;
class Main {
enum Size {
SMALL, MEDIUM, LARGE, EXTRALARGE
}
public static void main(String[] args) {
// Creating an EnumMap of the Size enum
EnumMap<Size, Integer> sizes1 = new EnumMap<>(Size.class);
// Using the put() Method
sizes1.put(Size.SMALL, 28);
sizes1.put(Size.MEDIUM, 32);
System.out.println("EnumMap1: " + sizes1);
EnumMap<Size, Integer> sizes2 = new EnumMap<>(Size.class);
// Using the putAll() Method
sizes2.putAll(sizes1);
sizes2.put(Size.LARGE, 36);
System.out.println("EnumMap2: " + sizes2);
}
}
Salida
EnumMap1: {SMALL = 28, MEDIUM = 32} EnumMap2: {PEQUEÑO = 28, MEDIO = 32, GRANDE = 36}
En el ejemplo anterior, hemos utilizado el
putAll()
método para insertar todos los elementos de un mapa de enumeración tamaños1 en un mapa de enumeración de tamaños2 .
También es posible insertar elementos de otros mapas, tales como
HashMap
, TreeMap
, etc. a un mapa enum usando putAll()
. Sin embargo, todos los mapas deben ser del mismo tipo de enumeración.Acceder a elementos de EnumMap
1. Usando entrySet (), keySet () y values ()
entrySet()
- devuelve un conjunto de todas las claves / valores de mapeo (entrada) de un mapa de enumeraciónkeySet()
- devuelve un conjunto de todas las claves de un mapa de enumeraciónvalues()
- devuelve un conjunto de todos los valores de un mapa de enumeración
Por ejemplo,
import java.util.EnumMap;
class Main {
enum Size {
SMALL, MEDIUM, LARGE, EXTRALARGE
}
public static void main(String[] args) {
// Creating an EnumMap of the Size enum
EnumMap<Size, Integer> sizes = new EnumMap<>(Size.class);
sizes.put(Size.SMALL, 28);
sizes.put(Size.MEDIUM, 32);
sizes.put(Size.LARGE, 36);
sizes.put(Size.EXTRALARGE, 40);
System.out.println("EnumMap: " + sizes);
// Using the entrySet() Method
System.out.println("Key/Value mappings: " + sizes.entrySet());
// Using the keySet() Method
System.out.println("Keys: " + sizes.keySet());
// Using the values() Method
System.out.println("Values: " + sizes.values());
}
}
Salida
EnumMap: {PEQUEÑO = 28, MEDIO = 32, GRANDE = 36, EXTRALARGE = 40} Asignaciones de clave / valor: [PEQUEÑO = 28, MEDIO = 32, GRANDE = 36, EXTRALARGE = 40] Claves: [PEQUEÑO, MEDIO, GRANDE, EXTRALARGE] Valores: [28, 32, 36, 40]
2. Usando el método get ()
El
get()
método devuelve el valor asociado con la clave especificada. Regresa null
si no se encuentra la clave especificada.
Por ejemplo,
import java.util.EnumMap;
class Main {
enum Size {
SMALL, MEDIUM, LARGE, EXTRALARGE
}
public static void main(String[] args) {
// Creating an EnumMap of the Size enum
EnumMap<Size, Integer> sizes = new EnumMap<>(Size.class);
sizes.put(Size.SMALL, 28);
sizes.put(Size.MEDIUM, 32);
sizes.put(Size.LARGE, 36);
sizes.put(Size.EXTRALARGE, 40);
System.out.println("EnumMap: " + sizes);
// Using the get() Method
int value = sizes.get(Size.MEDIUM);
System.out.println("Value of MEDIUM: " + value);
}
}
Salida
EnumMap: {PEQUEÑO = 28, MEDIO = 32, GRANDE = 36, EXTRALARGE = 40} Valor del MEDIO: 32
Eliminar elementos de EnumMap
remove(key)
- devuelve y elimina la entrada asociada con la clave especificada del maparemove(key, value)
- elimina la entrada del mapa solo si la clave especificada se asigna al valor especificado y devuelve un valor booleano
Por ejemplo,
import java.util.EnumMap;
class Main {
enum Size {
SMALL, MEDIUM, LARGE, EXTRALARGE
}
public static void main(String[] args) {
// Creating an EnumMap of the Size enum
EnumMap<Size, Integer> sizes = new EnumMap<>(Size.class);
sizes.put(Size.SMALL, 28);
sizes.put(Size.MEDIUM, 32);
sizes.put(Size.LARGE, 36);
sizes.put(Size.EXTRALARGE, 40);
System.out.println("EnumMap: " + sizes);
// Using the remove() Method
int value = sizes.remove(Size.MEDIUM);
System.out.println("Removed Value: " + value);
boolean result = sizes.remove(Size.SMALL, 28);
System.out.println("Is the entry {SMALL=28} removed? " + result);
System.out.println("Updated EnumMap: " + sizes);
}
}
Salida
EnumMap: {PEQUEÑO = 28, MEDIO = 32, GRANDE = 36, EXTRALARGE = 40} Valor eliminado: 32 ¿Se ha eliminado la entrada {SMALL = 28}? Cierto EnumMap actualizado: {LARGE = 36, EXTRALARGE = 40}
Reemplazar elementos de EnumMap
replace(key, value)
- reemplaza el valor asociado con la clave especificada por el nuevo valorreplace(key, old, new)
- reemplaza el antiguo valor con el nuevo valor sólo si el antiguo valor ya está asociada a la especificada clavereplaceAll(function)
- reemplaza cada valor del mapa con el resultado de la función especificada
import java.util.EnumMap;
class Main {
enum Size {
SMALL, MEDIUM, LARGE, EXTRALARGE
}
public static void main(String[] args) {
// Creating an EnumMap of the Size enum
EnumMap<Size, Integer> sizes = new EnumMap<>(Size.class);
sizes.put(Size.SMALL, 28);
sizes.put(Size.MEDIUM, 32);
sizes.put(Size.LARGE, 36);
sizes.put(Size.EXTRALARGE, 40);
System.out.println("EnumMap: " + sizes);
// Using the replace() Method
sizes.replace(Size.MEDIUM, 30);
sizes.replace(Size.LARGE, 36, 34);
System.out.println("EnumMap using replace(): " + sizes);
// Using the replaceAll() Method
sizes.replaceAll((key, oldValue) -> oldValue + 3);
System.out.println("EnumMap using replaceAll(): " + sizes);
}
}
Salida
EnumMap: {PEQUEÑO = 28, MEDIO = 32, GRANDE = 36, EXTRALARGE = 40} EnumMap usando replace (): {SMALL = 28, MEDIUM = 30, LARGE = 34, EXTRALARGE = 40} EnumMap usando replaceAll (): {SMALL = 31, MEDIUM = 33, LARGE = 37, EXTRALARGE = 43}
En el programa anterior, observe la declaración
sizes.replaceAll((key, oldValue) -> oldValue + 3);
Aquí, el método accede a todas las entradas del mapa. Luego reemplaza todos los valores con los nuevos valores proporcionados por las expresiones lambda .
Otros metodos
Método | Descripción |
---|---|
clone() | Crea una copia de EnumMap |
containsKey()
| Busca la EnumMap clave especificada y devuelve un resultado booleano. |
containsValue() | Busca el EnumMap valor especificado y devuelve un resultado booleano. |
size()
| Devuelve el tamaño de EnumMap |
clear() | Elimina todas las entradas del EnumMap |
EnumSet Vs. EnumMap
Tanto EnumSet como la
EnumMap
clase proporcionan una estructura de datos para almacenar valores de enumeración. Sin embargo, existen algunas diferencias importantes entre ellos.- El conjunto de enumeraciones se representa internamente como una secuencia de bits, mientras que el mapa de enumeraciones se representa internamente como matrices.
- Conjunto Enum se crea utilizando sus métodos predefinidos como
allOf()
,noneOf()
,of()
, etc. Sin embargo, un mapa enum se crea usando su constructor.
Interfaces clonables y serializables
La
EnumMap
clase también implementa Cloneable
e Serializable
interfaces.
Interfaz clonable
Permite que la
EnumMap
clase haga una copia de las instancias de la clase.
Interfaz serializable
Siempre que los objetos Java necesiten transmitirse a través de una red, los objetos deben convertirse en bits o bytes. Esto se debe a que los objetos Java no se pueden transmitir a través de la red.
La
Serializable
interfaz permite que las clases se serialicen. Esto significa que los objetos de la implementación de clases Serializable
se pueden convertir en bits o bytes.
0 Comentarios
Dejanos tu comentario para seguir mejorando!