博客
关于我
JavaSE—枚举
阅读量:638 次
发布时间:2019-03-14

本文共 3480 字,大约阅读时间需要 11 分钟。

枚举(Enum)是一种在Java中定义常量的强类型,允许代码中使用这些常量来表示一系列有限的、互不相同的值。通过 enum 关键字,我们可以创建一个自定义的枚举类型,这样在代码中引用这些常量就不再是 String 或其他任意类型,而是具体的枚举类型。

1、枚举的常规用法

package test;enum Day {    MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY, SUNDAY;}public class Test {    public static void main(String[] args) {        Day day = Day.MONDAY;        System.out.println(day.ordinal()); // 输出0    }}

编译器会将枚举类型 Day 生成一个继承自 java.lang.Enum 的类,因此,你可以使用 ordinal() 方法获取枚举常量的序数。

2、枚举对象的方法

每个枚举常量都有 name()toString() 方法,调用这些方法会返回该常量的文本表示。例如:

Day.MONDAY.name(); // 返回"MONDAY"Day.MONDAY.toString(); // 返回"MONDAY"

3、枚举的实际应用

枚举类型在实际开发中有很多用途,比如在 switch 语句中使用:

public class Test {    public enum Color {        RED, BLUE, GREEN    }    Color color = Color.RED;    public void change() {        switch (color) {            case RED:                color = Color.BLUE;                break;            case BLUE:                color = Color.GREEN;                break;            case GREEN:                color = Color.RED;                break;        }    }}

4、实现自定义逻辑

如果你想为枚举常量添加额外功能,可以在 enum 常量的定义后面添加逻辑。例如:

public enum Color {    RED("红色", 1), BLUE("蓝色", 2), GREEN("绿色", 3);    private String name;    private int index;    private Color(String name, int index) {        this.name = name;        this.index = index;    }    public String getName() {        return name;    }    public int getIndex() {        return index;    }    public static String getName(int index) {        for (Color c : Color.values()) {            if (c.getIndex() == index) {                return c.name;            }        }        return null;    }    @Override    public String toString() {        return super.toString();    }}

你可以通过 ordinal()name() 方法访问枚举的序号和名称,还可以通过 compareTo() 方法比较两个枚举值的顺序。

5、枚举与接口结合使用

由于 Enum 类本身已继承自 java.lang.Enum,所以我们可以让枚举类型实现接口。例如:

interface Behaviour {    void print();}public enum Color implements Behaviour {    RED("红色", 1), BLUE("蓝色", 2), GREEN("绿色", 3);    private String name;    private int index;    private Color(String name, int index) {        this.name = name;        this.index = index;    }    public String getName() {        return name;    }    public int getIndex() {        return index;    }    @Override    public void print() {        System.out.print(index + ":" + name);    }}public class Test {    public static void main(String[] args) {        Color.BLUE.print(); // 输出"2:蓝色"    }}

6、在接口中声明枚举

有时候,我们可能会把枚举类型定义在接口中,这样可以让所有实现该接口的类都共享相同的枚举值。例如:

interface Thing {    enum Mobile implements Thing {        SamSung("三星"), Apple("6");        private String type;        private Mobile(String type) {            this.type = type;        }        public String getType() {            return type;        }    }}public class Test implements Thing {    public static void main(String[] args) {        System.out.println(Mobile.SamSung.getType());    }}

7、枚举集合和映射

为了更高效地工作sWith枚举值,可以使用 java.util.EnumSetjava.util.EnumMap 这些辅助类。EnumSet 可以确保集合中仅包含枚举值,而 EnumMap 则可以使用枚举类型作为键。

例如:

import java.util.EnumSet;import java.util.EnumMap;public class Test {    public enum Direction { LEFT, RIGHT, UP, DOWN }    public static void main(String[] args) {        EnumSet
directions = EnumSet.of(Direction.LEFT, Direction.RIGHT); System.out.println(directions); // 输出{LEFT, RIGHT} EnumMap
map = new EnumMap
(); map.put(Direction.LEFT, "左"); map.put(Direction.RIGHT, "右"); System.out.println(map.get Direction.LEFT); // 输出"左" }}

转载地址:http://widlz.baihongyu.com/

你可能感兴趣的文章
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>