网站专题BANNER

深入理解 Java 枚举(enum) 7种常见的用法

发表日期:2021-11-01 21:01:00 文章编辑:洛壹网络 文章来源:深圳网站制作

用法一:常量

在JDK1.5之前,我们定义常量都是:publicstaticfianl....。现在好了,有了枚举,可以把相关的常量分组到一个枚举类型里,而且枚举提供了比常量更多的方法。


网站开发技术之深入理解 Java 枚举(enum) 7种常见的用法


Java代码

public enum Color {  

  RED, GREEN, BLANK, YELLOW  

}  


用法二:switch

JDK1.6之前的switch语句只支持int,char,enum类型,使用枚举,能让我们的代码可读性更强。


Java代码

enum Signal {  

    GREEN, YELLOW, RED  

}  

public class TrafficLight {  

    Signal color = Signal.RED;  

    public void change() {  

        switch (color) {  

        case RED:  

            color = Signal.GREEN;  

            break;  

        case YELLOW:  

            color = Signal.RED;  

            break;  

        case GREEN:  

            color = Signal.YELLOW;  

            break;  

        }  

    }  

}  


用法三:向枚举中添加新方法

如果打算自定义自己的方法,那么必须在enum实例序列的最后添加一个分号。而且Java要求必须先定义enum实例。


Java代码

public enum Color {  

    RED("红色", 1), GREEN("绿色", 2), BLANK("白色", 3), YELLO("黄色", 4);  

    // 成员变量  

    private String name;  

    private int index;  

    // 构造方法  

    private Color(String name, int index) {  

        this.name = name;  

        this.index = index;  

    }  

    // 普通方法  

    public static String getName(int index) {  

        for (Color c : Color.values()) {  

            if (c.getIndex() == index) {  

                return c.name;  

            }  

        }  

        return null;  

    }  

    // get set 方法  

    public String getName() {  

        return name;  

    }  

    public void setName(String name) {  

        this.name = name;  

    }  

    public int getIndex() {  

        return index;  

    }  

    public void setIndex(int index) {  

        this.index = index;  

    }  

}  


用法四:覆盖枚举的方法

下面给出一个toString()方法覆盖的例子。


Java代码

public enum Color {  

    RED("红色", 1), GREEN("绿色", 2), BLANK("白色", 3), YELLO("黄色", 4);  

    // 成员变量  

    private String name;  

    private int index;  

    // 构造方法  

    private Color(String name, int index) {  

        this.name = name;  

        this.index = index;  

    }  

    //覆盖方法  

    @Override  

    public String toString() {  

        return this.index+"_"+this.name;  

    }  

}  

 

用法五:实现接口

所有的枚举都继承自java.lang.Enum类。由于Java不支持多继承,所以枚举对象不能再继承其他类。


Java代码

public interface Behaviour {  

    void print();  

    String getInfo();  

}  

public enum Color implements Behaviour{  

    RED("红色", 1), GREEN("绿色", 2), BLANK("白色", 3), YELLO("黄色", 4);  

    // 成员变量  

    private String name;  

    private int index;  

    // 构造方法  

    private Color(String name, int index) {  

        this.name = name;  

        this.index = index;  

    }  

//接口方法  

    @Override  

    public String getInfo() {  

        return this.name;  

    }  

    //接口方法  

    @Override  

    public void print() {  

        System.out.println(this.index+":"+this.name);  

    }  

}   


用法六:使用接口组织枚举


Java代码

public interface Food {  

    enum Coffee implements Food{  

        BLACK_COFFEE,DECAF_COFFEE,LATTE,CAPPUCCINO  

    }  

    enum Dessert implements Food{  

        FRUIT, CAKE, GELATO  

    }  

}  

 

用法七:关于枚举集合的使用

java.util.EnumSet和java.util.EnumMap是两个枚举集合。EnumSet保证集合中的元素不重复;EnumMap中的key是enum类型,而value则可以是任意类型。


网站开发技术之深入理解 Java 枚举(enum) 7种常见的用法


相关内容
今天给大家分享一波前端开发者实用干货合集

今天洛壹网络给大家来一波实用的设计和开发类的干货素材合集吧!这次的合集依然是更加偏重开发和前端的需求,有一些颇为有趣的桌面应用程序,一些非常方便的 Web 应用,以及一些实用性很强的 JavaScript 库。

前端开发 meta name="viewport" 的用法

移动端的布局不同于pc端,首先我们要知道在移动端中,css中的1px并不等于物理上的1px,因为手机屏幕的分辨率已经越来越高,高像素但是屏幕尺寸却没有发生太大变化,那就意味着一个物理像素点实际上塞入了好几个像素。

网页制作中什么是相对定位什么是绝对定位?

定位为相对定位(relative)的元素脱离文档流,但其在文档流中的位置依然存在。定位为绝对定位(absolute)的元素脱离文档流,但与relative的区别是其在文档流的位置不再存在。

响应式网站建设需要什么样的技术?

响应式布局可以为不同终端的用户提供更加舒适的界面和更好的用户体验,而且随着大屏幕移动设备的普及,用“大势所趋”来形容也不为过。

HTTP(超文本传输协议)的六种请求方法介绍

超文本传输协议(Hyper Text Transfer Protocol,HTTP)是一个简单的请求-响应协议,它通常运行在TCP之上。它指定了客户端可能发送给服务器什么样的消息以及得到什么样的响应。

web开发人员需要掌握的编程技能有哪些?

web开发所需的编程知识随着时间的推移而不同,这取决于你想要做什么。那么web前端开发最新的编程技能和知识有哪些呢?

JavaScrip 前端/后台开发人员必须要掌握的编程技能

在每年最受欢迎的编程语言排行榜中,javascript一直处于领先地位,而2021年,它依然会是最受欢迎的编程语言。

浅谈弹性布局在网站建设过程中的奇妙之处

熟练掌握CSS弹性布局的话,无论是页面的整体设计还是局部内容的布局,都能起到事半功倍的效果,今天洛壹网络简单为大家讲解一下CSS弹性布局的奇妙之处。

我们
定制
咨询
联系
在线咨询
您的浏览器版本太低

请升级您的浏览器: Internet Explorer11 或以下浏览器: Firefox  /  Chrome  /  360极速浏览器