जवाबों:
हां, Blah.valueOf("A")
आपको देंगे Blah.A
।
ध्यान दें कि नाम केस सहित एक सटीक मिलान होना चाहिए : Blah.valueOf("a")
और Blah.valueOf("A ")
दोनों एक फेंक देते हैं IllegalArgumentException
।
स्थिर तरीके valueOf()
और values()
संकलन समय पर बनाए जाते हैं और स्रोत कोड में दिखाई नहीं देते हैं। वे हालांकि, जावदोक में दिखाई देते हैं; उदाहरण के लिए, Dialog.ModalityType
दोनों विधियों को दर्शाता है।
toString()
मूल्य का मतलब है , नहीं, मैं यह नहीं कहूंगा। name()
जब तक आप इसे ओवरराइड नहीं करते तब तक आपको एनम स्थिरांक का वास्तविक परिभाषित नाम मिलेगा।
enum Blah {...}
परिभाषा को अपनी values
और न ही घोषित करने की कोशिश नहीं करनी चाहिए valuesOf
। यह ऐसा है कि आप "AnyTypeName.class" कैसे लिख सकते हैं, भले ही आपने वास्तव में "वर्ग" सदस्य चर घोषित न किया हो; संकलक यह सब बस काम करता है। (यह उत्तर अब आपके लिए उपयोगी नहीं हो सकता है 3 महीने बाद, लेकिन सिर्फ मामले में।)
एक और समाधान यदि पाठ एन्यूमरेशन मान के समान नहीं है:
public enum Blah {
A("text1"),
B("text2"),
C("text3"),
D("text4");
private String text;
Blah(String text) {
this.text = text;
}
public String getText() {
return this.text;
}
public static Blah fromString(String text) {
for (Blah b : Blah.values()) {
if (b.text.equalsIgnoreCase(text)) {
return b;
}
}
return null;
}
}
throw new IllegalArgumentException("No constant with text " + text + " found")
से बेहतर होगा return null
।
यहाँ एक उपयोगी उपयोगिता है जिसका मैं उपयोग करता हूँ:
/**
* A common method for all enums since they can't have another base class
* @param <T> Enum type
* @param c enum type. All enums must be all caps.
* @param string case insensitive
* @return corresponding enum, or null
*/
public static <T extends Enum<T>> T getEnumFromString(Class<T> c, String string) {
if( c != null && string != null ) {
try {
return Enum.valueOf(c, string.trim().toUpperCase());
} catch(IllegalArgumentException ex) {
}
}
return null;
}
तब मेरे एनम वर्ग में आमतौर पर कुछ टाइपिंग को बचाने के लिए मेरे पास यह होता है:
public static MyEnum fromString(String name) {
return getEnumFromString(MyEnum.class, name);
}
यदि आपके एनम सभी कैप नहीं हैं, तो बस Enum.valueOf
लाइन बदलें ।
बहुत बुरा मैं उपयोग नहीं कर सकते T.class
के लिए Enum.valueOf
के रूप में T
मिटा दिया जाता है।
जोशुआ बलोच, प्रभावी जावा से पैटर्न का उपयोग करें :
(संक्षिप्तता के लिए सरलीकृत)
enum MyEnum {
ENUM_1("A"),
ENUM_2("B");
private String name;
private static final Map<String,MyEnum> ENUM_MAP;
MyEnum (String name) {
this.name = name;
}
public String getName() {
return this.name;
}
// Build an immutable map of String name to enum pairs.
// Any Map impl can be used.
static {
Map<String,MyEnum> map = new ConcurrentHashMap<String, MyEnum>();
for (MyEnum instance : MyEnum.values()) {
map.put(instance.getName(),instance);
}
ENUM_MAP = Collections.unmodifiableMap(map);
}
public static MyEnum get (String name) {
return ENUM_MAP.get(name);
}
}
और देखें:
उदाहरण के Enum और मानचित्र का उपयोग करते हुए Oracle जावा उदाहरण
Stream.of(MyEnum.values()).collect(toMap(Enum::name, identity()))
मैं भी ओवरराइडिंग () (कंस्ट्रक्टर के माध्यम से पारित) और नाम के बजाय इसका उपयोग करने की सलाह देता हूं, खासकर अगर Enum क्रमबद्ध डेटा के साथ जुड़ा हुआ है क्योंकि इससे आप बिना दिए गए कैसर को नियंत्रित कर सकते हैं। सोनार एक फिट।
unmodifiableMap
भी तरह से डालने जा रहे हैं , तो ए के साथ शुरू करने का कोई लाभ नहीं है ConcurrentHashMap
। बस एक का उपयोग करें HashMap
। (यदि आपके पास अमरूद है, ImmutableMap
तो मैं इसके बजाय इसकी सलाह
ConcurrentHashMap
यहां उपयोग करने का कोई कारण नहीं है, जहां मानचित्र को आरंभीकरण के बाद कभी भी संशोधित नहीं किया जाता है। इसलिए भी उदाहरण के लिए जेएलएस में ही उदाहरण एक नियमित का उपयोग करता है HashMap
।
आपको अपने मामले से भी सावधान रहना चाहिए। मुझे समझाने दो: Blah.valueOf("A")
काम कर रहा है, लेकिन Blah.valueOf("a")
काम नहीं करेगा। फिर Blah.valueOf("a".toUpperCase(Locale.ENGLISH))
काम करेगा।
संपादित
बदल दिया toUpperCase
करने toUpperCase(Locale.ENGLISH)
के आधार पर टीसी। टिप्पणी और जावा डॉक्स
EDIT2
पर आप का उपयोग करना चाहिए android Locale.US
के रूप में, sulai बताते हैं ।
Locale.US
मशीन पठनीय इनपुट / आउटपुट के उपयोग को प्रोत्साहित करता है ।
यहाँ एक विधि है जो इसे किसी भी Enum के लिए कर सकती है, और यह असंवेदनशील है।
/**
* Finds the value of the given enumeration by name, case-insensitive.
* Throws an IllegalArgumentException if no match is found.
**/
public static <T extends Enum<T>> T valueOfIgnoreCase(
Class<T> enumeration, String name) {
for (T enumValue : enumeration.getEnumConstants()) {
if (enumValue.name().equalsIgnoreCase(name)) {
return enumValue;
}
}
throw new IllegalArgumentException(String.format(
"There is no value with name '%s' in Enum %s",
name, enumeration.getName()
));
}
equalsIgnoreCase
जाने का रास्ता है। +1
का उपयोग करना Blah.valueOf(string)
सबसे अच्छा है लेकिन आप भी उपयोग कर सकते हैं Enum.valueOf(Blah.class, string)
।
जावा 8 या बाद में, स्ट्रीम का उपयोग करते हुए :
public enum Blah
{
A("text1"),
B("text2"),
C("text3"),
D("text4");
private String text;
Blah(String text) {
this.text = text;
}
public String getText() {
return this.text;
}
public static Optional<Blah> fromText(String text) {
return Arrays.stream(values())
.filter(bl -> bl.text.equalsIgnoreCase(text))
.findFirst();
}
}
यदि आप अपनी उपयोगिता लिखने के लिए Google का उपयोग नहीं करना चाहते हैं अमरूद पुस्तकालय:
Enums.getIfPresent(Blah.class, "A")
बिल्ट इन जावा फंक्शन के विपरीत, आइए हम जांचते हैं कि क्या ए ब्लाह में मौजूद है और कोई अपवाद नहीं है।
मेरे 2 सेंट यहाँ: Java8 स्ट्रीम का उपयोग करके + एक सटीक स्ट्रिंग की जाँच:
public enum MyEnum {
VALUE_1("Super"),
VALUE_2("Rainbow"),
VALUE_3("Dash"),
VALUE_3("Rocks");
private final String value;
MyEnum(String value) {
this.value = value;
}
/**
* @return the Enum representation for the given string.
* @throws IllegalArgumentException if unknown string.
*/
public static MyEnum fromString(String s) throws IllegalArgumentException {
return Arrays.stream(MyEnum.values())
.filter(v -> v.value.equals(s))
.findFirst()
.orElseThrow(() -> new IllegalArgumentException("unknown value: " + s));
}
}
** EDIT **
fromString()
उस कन्वेंशन का नामकरण करने के बाद से फ़ंक्शन का नाम दिया गया है, आपको जावा भाषा से ही कुछ लाभ मिलेंगे; उदाहरण के लिए:
switch
ब्लॉक लिखने की अनुमति देने के लिए , आप .orElse(null)
इसके बजाय, .orElseThrow()
ताकि आप default
क्लॉज में अपवाद फेंक को कोड कर सकें - और आवश्यकता पड़ने पर अधिक उपयोगी जानकारी शामिल कर सकें । और इसे और अधिक उदार बनाने के लिए आप उपयोग कर सकते हैंv -> Objects.equals(v.name, s == null ? "" : s.trim().toUpperCase())
Optional
से findFirst()
, वह चाहता है, तो उपयोगकर्ता को यह तय करने की इजाजत दी .orElse(null)
, orElseThrow()
या जो कुछ भी ....
आपको इसकी आवश्यकता हो सकती है:
public enum ObjectType {
PERSON("Person");
public String parameterName;
ObjectType(String parameterName) {
this.parameterName = parameterName;
}
public String getParameterName() {
return this.parameterName;
}
//From String method will return you the Enum for the provided input string
public static ObjectType fromString(String parameterName) {
if (parameterName != null) {
for (ObjectType objType : ObjectType.values()) {
if (parameterName.equalsIgnoreCase(objType.parameterName)) {
return objType;
}
}
}
return null;
}
}
एक और अतिरिक्त:
public static String fromEnumName(String parameterName) {
if (parameterName != null) {
for (DQJ objType : DQJ.values()) {
if (parameterName.equalsIgnoreCase(objType.name())) {
return objType.parameterName;
}
}
}
return null;
}
यह आपको स्ट्रिंग नामांकित नाम से मान लौटाएगा जैसे कि यदि आप fromEnumName में "PERSON" प्रदान करते हैं तो यह आपको Enum का मान लौटाएगा अर्थात "व्यक्ति"
name()
Enum के निहित स्थिर विधि का उपयोग करके ऐसा करने का दूसरा तरीका । नाम उस एनम को बनाने के लिए उपयोग की जाने वाली सटीक स्ट्रिंग को लौटाएगा जिसका उपयोग प्रदान किए गए स्ट्रिंग के खिलाफ जांच करने के लिए किया जा सकता है:
public enum Blah {
A, B, C, D;
public static Blah getEnum(String s){
if(A.name().equals(s)){
return A;
}else if(B.name().equals(s)){
return B;
}else if(C.name().equals(s)){
return C;
}else if (D.name().equals(s)){
return D;
}
throw new IllegalArgumentException("No Enum specified for this string");
}
}
परिक्षण:
System.out.println(Blah.getEnum("B").name());
//it will print B B
प्रेरणा: जावा में Enum के 10 उदाहरण
valueOf
आपके लिए क्या करता है। यह स्थिर विधि कुछ भी अतिरिक्त, अपवाद एट सभी की पेशकश नहीं करती है। तब यदि / अन्यथा निर्माण अत्यधिक खतरनाक होते हैं ... कोई भी नई ईनम निरंतर जोड़ी बिना बदलाव के इस पद्धति को तोड़ देगी।
name()
स्थिर नहीं है।
अमरूद पुस्तकालयों का उपयोग कर समाधान। विधि getPlanet () स्थिति असंवेदनशील है, इसलिए getPlanet ("MerCUrY") Planet.MERCURY वापस आ जाएगी।
package com.universe.solarsystem.planets;
import org.apache.commons.lang3.StringUtils;
import com.google.common.base.Enums;
import com.google.common.base.Optional;
//Pluto and Eris are dwarf planets, who cares!
public enum Planet {
MERCURY,
VENUS,
EARTH,
MARS,
JUPITER,
SATURN,
URANUS,
NEPTUNE;
public static Planet getPlanet(String name) {
String val = StringUtils.trimToEmpty(name).toUpperCase();
Optional <Planet> possible = Enums.getIfPresent(Planet.class, val);
if (!possible.isPresent()) {
throw new IllegalArgumentException(val + "? There is no such planet!");
}
return possible.get();
}
}
पिछले उत्तरों में जोड़ने के लिए, और nulls और NPE के आस-पास कुछ चर्चाओं को संबोधित कर रहा हूँ जो मैं अनुपस्थित / अमान्य मामलों को संभालने के लिए Guava Optionals का उपयोग कर रहा हूँ। यह यूआरआई / पैरामीटर पार्सिंग के लिए बहुत अच्छा काम करता है।
public enum E {
A,B,C;
public static Optional<E> fromString(String s) {
try {
return Optional.of(E.valueOf(s.toUpperCase()));
} catch (IllegalArgumentException|NullPointerException e) {
return Optional.absent();
}
}
}
जिन लोगों को जानकारी नहीं है, उनके लिए वैकल्पिक के साथ अशक्तता से बचने के बारे में कुछ और जानकारी: https://code.google.com/p/guava-lbooks/wiki/UsingAndAvoidingNullExplained#Optional
जावा 8 में स्थैतिक मानचित्र पैटर्न और भी आसान है और यह मेरी पूर्वनिर्मित विधि है। यदि आप जैक्सन के साथ एनम का उपयोग करना चाहते हैं, तो आप स्ट्रीडिंग को ओवरराइड कर सकते हैं और नाम के बजाय इसका उपयोग कर सकते हैं, तो एनोटेट के साथ@JsonValue
public enum MyEnum {
BAR,
BAZ;
private static final Map<String, MyEnum> MAP = Stream.of(MyEnum.values()).collect(Collectors.toMap(Enum::name, Function.identity()));
public static MyEnum fromName(String name){
return MAP.get(name);
}
}
public enum MyEnumForJson {
BAR("bar"),
BAZ("baz");
private static final Map<String, MyEnumForJson> MAP = Stream.of(MyEnumForJson.values()).collect(Collectors.toMap(Object::toString, Function.identity()));
private final String value;
MyEnumForJson(String value) {
this.value = value;
}
@JsonValue
@Override
public String toString() {
return value;
}
public static MyEnumForJson fromValue(String value){
return MAP.get(value);
}
}
public static MyEnum getFromValue(String value) {
MyEnum resp = null;
MyEnum nodes[] = values();
for(int i = 0; i < nodes.length; i++) {
if(nodes[i].value.equals(value)) {
resp = nodes[i];
break;
}
}
return resp;
}
हे (1) विधि थ्रोट जनरेट कोड से प्रेरित है जो हैशमैप का उपयोग करता है।
public enum USER {
STUDENT("jon",0),TEACHER("tom",1);
private static final Map<String, Integer> map = new HashMap<>();
static {
for (USER user : EnumSet.allOf(USER.class)) {
map.put(user.getTypeName(), user.getIndex());
}
}
public static int findIndexByTypeName(String typeName) {
return map.get(typeName);
}
private USER(String typeName,int index){
this.typeName = typeName;
this.index = index;
}
private String typeName;
private int index;
public String getTypeName() {
return typeName;
}
public void setTypeName(String typeName) {
this.typeName = typeName;
}
public int getIndex() {
return index;
}
public void setIndex(int index) {
this.index = index;
}
}
एनम बहुत उपयोगी है, मैं Enum
विभिन्न भाषाओं में कुछ क्षेत्रों के लिए विवरण जोड़ने के लिए बहुत उपयोग कर रहा हूं , निम्न उदाहरण के रूप में:
public enum Status {
ACT(new String[] { "Accepted", "مقبول" }),
REJ(new String[] { "Rejected", "مرفوض" }),
PND(new String[] { "Pending", "في الانتظار" }),
ERR(new String[] { "Error", "خطأ" }),
SNT(new String[] { "Sent", "أرسلت" });
private String[] status;
public String getDescription(String lang) {
return lang.equals("en") ? status[0] : status[1];
}
Status(String[] status) {
this.status = status;
}
}
और फिर आप getDescription(String lang)
उदाहरण के लिए, विधि के लिए पारित भाषा कोड में गतिशील रूप से विवरण प्राप्त कर सकते हैं :
String statusDescription = Status.valueOf("ACT").getDescription("en");
java.lang.Enum
कई उपयोगी तरीकों को परिभाषित करता है, जो जावा में सभी एन्यूमरेशन प्रकार के लिए उपलब्ध है:
name()
किसी भी Enum स्थिरांक का नाम प्राप्त करने के लिए विधि का । Enum constants लिखने के लिए इस्तेमाल किया जाने वाला स्ट्रिंग शाब्दिक नाम है।values()
एक Enum प्रकार से सभी Enum स्थिरांक की एक सरणी प्राप्त करने के लिए विधि का उपयोग किया जा सकता है।valueOf()
किसी भी स्ट्रिंग को जावा में Enum स्थिरांक में बदलने के लिए विधि का उपयोग कर सकते हैं , जैसा कि नीचे दिखाया गया है।public class EnumDemo06 {
public static void main(String args[]) {
Gender fromString = Gender.valueOf("MALE");
System.out.println("Gender.MALE.name() : " + fromString.name());
}
private enum Gender {
MALE, FEMALE;
}
}
Output:
Gender.MALE.name() : MALE
इस कोड स्निपेट में, valueOf()
विधि एक Enum निरंतर Gender.MALE लौटाती है, जो उस रिटर्न पर कॉलिंग नाम है "MALE"
।
अपाचे के कॉमन्स-लैंग लाइब्रेरी में स्टैटिक फंक्शन org.apache.commons.lang3.EnumUtils.getEnum है जो आपके Enum टाइप करने के लिए एक स्ट्रिंग को मैप करेगा। अनिवार्य रूप से Geoffreys के रूप में एक ही जवाब है, लेकिन क्यों अपने खुद के रोल जब यह वहाँ पहले से ही जंगली में है।
एक उपयोगी उपयोगिता के साथ शीर्ष रेटेड उत्तर में जोड़ना ...
valueOf()
उन मामलों में दो अलग-अलग अपवादों को फेंकता है जहां यह अपने इनपुट को पसंद नहीं करता है।
IllegalArgumentException
NullPointerExeption
यदि आपकी आवश्यकताएं ऐसी हैं कि आपके पास कोई गारंटी नहीं है कि आपका स्ट्रिंग निश्चित रूप से एनम मूल्य से मेल खाएगा, उदाहरण के लिए यदि स्ट्रिंग डेटा डेटाबेस से आता है और इसमें एनम का पुराना संस्करण हो सकता है, तो आपको इन्हें संभालने की आवश्यकता होगी अक्सर ...
तो यहाँ एक पुन: प्रयोज्य विधि मैंने लिखी है जो हमें एक डिफ़ॉल्ट Enum को परिभाषित करने की अनुमति देती है यदि स्ट्रिंग हम पास नहीं करते हैं तो मिलान नहीं होता है।
private static <T extends Enum<T>> T valueOf( String name , T defaultVal) {
try {
return Enum.valueOf(defaultVal.getDeclaringClass() , name);
} catch (IllegalArgumentException | NullPointerException e) {
return defaultVal;
}
}
इसे इस तरह उपयोग करें:
public enum MYTHINGS {
THINGONE,
THINGTWO
}
public static void main(String [] asd) {
valueOf("THINGTWO" , MYTHINGS.THINGONE);//returns MYTHINGS.THINGTWO
valueOf("THINGZERO" , MYTHINGS.THINGONE);//returns MYTHINGS.THINGONE
}
के रूप में switch
-version का उल्लेख अभी तक नहीं किया गया है, मैं इसे शुरू करता हूं (ओप्स एनम का पुन: उपयोग):
private enum Blah {
A, B, C, D;
public static Blah byName(String name) {
switch (name) {
case "A":
return A;
case "B":
return B;
case "C":
return C;
case "D":
return D;
default:
throw new IllegalArgumentException(
"No enum constant " + Blah.class.getCanonicalName() + "." + name);
}
}
}
चूँकि यह valueOf(String name)
विधि को कोई अतिरिक्त मूल्य नहीं देता है , यह केवल एक अतिरिक्त विधि को परिभाषित करने के लिए समझ में आता है अगर हम एक अलग व्यवहार चाहते हैं। यदि हम नहीं उठाना चाहते हैं तो IllegalArgumentException
हम कार्यान्वयन को बदल सकते हैं:
private enum Blah {
A, B, C, D;
public static Blah valueOfOrDefault(String name, Blah defaultValue) {
switch (name) {
case "A":
return A;
case "B":
return B;
case "C":
return C;
case "D":
return D;
default:
if (defaultValue == null) {
throw new NullPointerException();
}
return defaultValue;
}
}
}
एक डिफ़ॉल्ट मूल्य प्रदान करके हम उस तरीके से बिना किसी अनुबंध के Enum.valueOf(String name)
फेंक IllegalArgumentException
देते हैं कि किसी भी स्थिति null
में वापस नहीं किया जाता है। इसलिए हम फेंक देते हैं NullPointerException
यदि नाम है null
और default
यदि defaultValue
है तो null
। कि कैसेvalueOfOrDefault
काम करता है।
यह दृष्टिकोण -इंटरफेस के डिज़ाइन को अपनाता है Map
जो Map.getOrDefault(Object key, V defaultValue)
जावा 8 के रूप में एक विधि प्रदान करता है ।
एक और उपयोगिता उल्टे तरीके से कैप्चर करना। एक मान का उपयोग करना जो उस एनम की पहचान करता है, उसके नाम से नहीं।
import java.lang.reflect.Method;
import java.lang.reflect.Modifier;
import java.util.EnumSet;
public class EnumUtil {
/**
* Returns the <code>Enum</code> of type <code>enumType</code> whose a
* public method return value of this Enum is
* equal to <code>valor</code>.<br/>
* Such method should be unique public, not final and static method
* declared in Enum.
* In case of more than one method in match those conditions
* its first one will be chosen.
*
* @param enumType
* @param value
* @return
*/
public static <E extends Enum<E>> E from(Class<E> enumType, Object value) {
String methodName = getMethodIdentifier(enumType);
return from(enumType, value, methodName);
}
/**
* Returns the <code>Enum</code> of type <code>enumType</code> whose
* public method <code>methodName</code> return is
* equal to <code>value</code>.<br/>
*
* @param enumType
* @param value
* @param methodName
* @return
*/
public static <E extends Enum<E>> E from(Class<E> enumType, Object value, String methodName) {
EnumSet<E> enumSet = EnumSet.allOf(enumType);
for (E en : enumSet) {
try {
String invoke = enumType.getMethod(methodName).invoke(en).toString();
if (invoke.equals(value.toString())) {
return en;
}
} catch (Exception e) {
return null;
}
}
return null;
}
private static String getMethodIdentifier(Class<?> enumType) {
Method[] methods = enumType.getDeclaredMethods();
String name = null;
for (Method method : methods) {
int mod = method.getModifiers();
if (Modifier.isPublic(mod) && !Modifier.isStatic(mod) && !Modifier.isFinal(mod)) {
name = method.getName();
break;
}
}
return name;
}
}
उदाहरण:
public enum Foo {
ONE("eins"), TWO("zwei"), THREE("drei");
private String value;
private Foo(String value) {
this.value = value;
}
public String getValue() {
return value;
}
}
EnumUtil.from(Foo.class, "drei")
रिटर्न Foo.THREE
, क्योंकि यह getValue
"ड्रि" से मेल खाने के लिए उपयोग करेगा , जो कि अद्वितीय सार्वजनिक है, अंतिम नहीं है और फू में स्थिर विधि नहीं है। यदि फू में सार्वजनिक से अधिक है, तो अंतिम नहीं और स्थिर विधि नहीं है, उदाहरण के लिए, getTranslate
जो "drei" लौटाता है, दूसरी विधि का उपयोग किया जा सकता है EnumUtil.from(Foo.class, "drei", "getTranslate")
:।
एक एक्सटेंशन बनाएं और फिर कॉल करें valueOf<MyEnum>("value")
। यदि प्रकार अमान्य है, तो आपको अशक्त हो जाएगा और इसे संभालना होगा
inline fun <reified T : Enum<T>> valueOf(type: String): T? {
return try {
java.lang.Enum.valueOf(T::class.java, type)
} catch (e: Exception) {
null
}
}
वैकल्पिक रूप से, आप एक डिफ़ॉल्ट मान सेट कर सकते हैं, कॉल कर सकते हैं valueOf<MyEnum>("value", MyEnum.FALLBACK)
, और अशक्त प्रतिक्रिया से बच सकते हैं। डिफ़ॉल्ट होने के लिए आप अपने विशिष्ट एनम का विस्तार कर सकते हैं स्वचालित
inline fun <reified T : Enum<T>> valueOf(type: String, default: T): T {
return try {
java.lang.Enum.valueOf(T::class.java, type)
} catch (e: Exception) {
default
}
}
या यदि आप दोनों चाहते हैं, तो दूसरा बनाएं:
inline fun <reified T : Enum<T>> valueOf(type: String, default: T): T = valueOf<T>(type) ?: default
मैं इस तरह की प्रक्रिया का उपयोग करने के लिए गणना में तार के रूप में आदेशों को पार्स करना पसंद करता हूं। मेरे पास सामान्य रूप से "अज्ञात" के रूप में गणना में से एक है, इसलिए यह उस स्थिति में मदद करता है जब दूसरों को नहीं मिला है (भले ही असंवेदनशील आधार पर) शून्य के बजाय (जिसका अर्थ है कि कोई मूल्य नहीं है)। इसलिए मैं इस दृष्टिकोण का उपयोग करता हूं।
static <E extends Enum<E>> Enum getEnumValue(String what, Class<E> enumClass) {
Enum<E> unknown=null;
for (Enum<E> enumVal: enumClass.getEnumConstants()) {
if (what.compareToIgnoreCase(enumVal.name()) == 0) {
return enumVal;
}
if (enumVal.name().compareToIgnoreCase("unknown") == 0) {
unknown=enumVal;
}
}
return unknown;
}
एनम का नाम पाने के लिए सबसे तेज़ तरीका है कि एनुम टेक्स्ट और वैल्यू का एक नक्शा बनाएं जब एप्लिकेशन शुरू हो, और नाम पाने के लिए फ़ंक्शन को कॉल करें Blah.getEnumName ():
public enum Blah {
A("text1"),
B("text2"),
C("text3"),
D("text4");
private String text;
private HashMap<String, String> map;
Blah(String text) {
this.text = text;
}
public String getText() {
return this.text;
}
static{
createMapOfTextAndName();
}
public static void createMapOfTextAndName() {
map = new HashMap<String, String>();
for (Blah b : Blah.values()) {
map.put(b.getText(),b.name());
}
}
public static String getEnumName(String text) {
return map.get(text.toLowerCase());
}
}
Blah.valueOf("A")
विधि संवेदनशील है और बाहरी व्हॉट्सएप को बर्दाश्त नहीं करती है, इस प्रकार @ JosMMi द्वारा प्रस्तावित वैकल्पिक समाधान है।