栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

使用Java 8 Stream API查找枚举值

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

使用Java 8 Stream API查找枚举值

我会

findFirst
改用:

return Arrays.stream(Type.values()) .filter(e -> e.s.equals(val)) .findFirst() .orElseThrow(() -> new IllegalStateException(String.format("Unsupported type %s.", val)));

尽管

Map
在这种情况下a 可能更好:

enum Type{    X("S1"),    Y("S2");    private static class Holder {        static Map<String, Type> MAP = new HashMap<>();    }    private Type(String s) {        Holder.MAP.put(s, this);    }    public static Type find(String val) {        Type t = Holder.MAP.get(val);        if(t == null) { throw new IllegalStateException(String.format("Unsupported type %s.", val));        }        return t;    }}

我从这个答案中学到了这个技巧。基本上,类加载器会在枚举类之前初始化静态类,这使您可以

Map
将枚举构造器本身填充。非常便利

您想要一个

Map<String, Code>
,但是如何整齐地填充它呢?枚举不允许您在初始化枚举实例之前初始化静态字段,但是有一个巧妙的小技巧,称为“ 按需初始化holder idiom”,它使使用此功能所需的静态初始化映射变得容易实现:

public enum Code {    CODE_1("string1"),    CODE_2("string2"),    CODE_3("string3"),    // etc    ;    private static class Holder {        static Map<String, Code> CODE_MAP = new HashMap<>();    }    private final String pre;    private Code(String pre) {        this.pre = pre;        Holder.CODE_MAP.put(pre, this);    }    public String getCode() {        return this.pre;    }    public Code convertFromString(String pre) {        return CODE_MAP.get(pre);    }}

之所以可行,是因为类加载器在初始化枚举类之前先初始化内部静态类,因此将映射分配为在枚举实例初始化期间准备加载。

没有循环。无需特殊代码即可加载地图(在构造函数中完成)。最少的代码。

希望能帮助到你 !:)



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/485962.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号