Java~枚举的使用

news/2024/5/18 22:37:22 标签: java, 枚举

目录

枚举的定义

枚举的使用

values()的使用 

ordinal()的使用

valueOf() 的使用

compareTo()的使用 

枚举的优缺点


枚举的定义

枚举是JDK1.5以后引入的。主要用途:将一组常量组织起来,在引入枚举之前表示一组常量通常是使用定义常量的方式:

    public static final int RED = 1;
    public static final int GREEN = 2;
    public static final int BLACK = 3;

在引入枚举后我们可以将上述的常量举例直接写成类的形式:

public enum TestEnum {
    RED,GREEN,BLACK;
}

枚举的优点:将常量统一组织起来管理

应用场景:错误状态码、消息类型、颜色的划分.......

本质:我们所定义的枚举类,是java.lang.Enum的子类,虽然在写枚举类的时候未写出其继承Enum类,但是其默认继承了这个类.

枚举的使用

Enum类常用的方法

方法名称描述
values()以数组形式返回枚举类型的所有成员
ordinal()获取枚举成员的索引位置
valueOf()将普通字符串转换为枚举示例
compareTo()比较两个枚举成员在定义时的顺序

通过构造方法,定义出一个枚举

public enum TestEnum {
    //枚举对象
    CAT("猫"),
    DOG("狗"),
    BIRD("鸟");

    public String animal;

    /**
     * 枚举的构造方法,默认是私有的
     * @param animal
     */
    TestEnum(String animal) {
        this.animal = animal;
    }
}

values()的使用 

 values()方法是以数组形式返回枚举类型的成员,定义一个枚举类型的数组接收枚举成员,再将其输出.

    public static void main(String[] args) {
        TestEnum[] testEnums = TestEnum.values();
        for(TestEnum x : testEnums){
            System.out.println(x);
        }
    }

运行结果 

ordinal()的使用

利用ordinal()方法可以获取枚举成员的索引位置,具体使用如下所示:

    public static void main(String[] args) {
        TestEnum[] testEnums = TestEnum.values();
        for(TestEnum x : testEnums){
            System.out.println(x + " " + x.ordinal());
        }
    }

运行结果 

 

valueOf() 的使用

在定义好枚举类之后,利用valueOf()方法将输入的字符串转换为枚举示例,再对其进行判断

    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        while(scan.hasNext()) {
            TestEnum testEnum = TestEnum.valueOf(scan.next());
            switch(testEnum) {
                case CAT:
                    System.out.println("猫");
                    break;
                case DOG:
                    System.out.println("狗");
                    break;
                case BIRD:
                    System.out.println("鸟");
                    break;
                default:
                    break;
            }
        }
    }

运行结果

compareTo()的使用 

通过对源码的分析,可以发现compareTo()方法的返回值为两个枚举对象的位置差值.

例如:

    public static void main(String[] args) {
        System.out.println(CAT.compareTo(DOG));
        System.out.println(DOG.compareTo(CAT));
        System.out.println(BIRD.compareTo(CAT));
        System.out.println(CAT.compareTo(BIRD));
    }

 运行结果

 以下列语句进行分析

System.out.println(CAT.compareTo(BIRD));

在定义枚举类时,CAT是默认下标为0的位置,BIRD是默认下标为2的位置,当两个进行比较时,返回的是CAT下标-BIRD下标,结果为-2; 

上述所有的示例代码已上传至gitee代码仓库中:点击查看代码 

枚举的优缺点

优点

1、枚举常量更简单安全;

2、枚举具有内置方法,代码更可观优雅

缺点

1、不可继承,无法扩展.

 

 

 

 


http://www.niftyadmin.cn/n/735926.html

相关文章

php中上传图片,原生代码

一、实现图片上传方法一 html的写法&#xff1a; <form action"handle.php" name"form" method"post" enctype"multipart/form-data"><input type"file" name"file" /><input type"submit&qu…

优化后的快速排序(详解)

目录 快速排序 三数取中值分割法获得枢纽元 快速排序的主例程 直接插入排序代码 快速排序完整代码 快速排序 快速排序是实践中的一种快速的排序算法&#xff0c;它的平均运行时间是O(N log N)&#xff0c;该算法之所以特别快&#xff0c;是因为它有非常精炼和高度优化的…

Java实现二叉查找树及其相关操作

目录 二叉查找树 初始化 二叉查找树的查找 二叉查找树的插入 二叉查找树的删除 二叉查找树的中序遍历 findMax and findMin 二叉查找树完整代码 测试用例 完整代码已上传至gitee中&#xff1a;gitee代码仓库 二叉查找树 二叉查找树&#xff0c;又称二叉排序树…

如何编写更好的SQL查询:终极指南-第二部分

基于集合和程序的方法进行查询 > > > > >

你了解直接进行访问的数据结构吗?一篇文章带你了解简单的哈希表的实现

目录 哈希表 哈希表的实现 初始化 计算负载因子 哈希表的扩容 哈希表的插入 查找元素 完整代码 测试用例 哈希表实现代码已上传至gitee中&#xff1a;点击查看代码 哈希表 哈希表(也称散列表)&#xff1a;是根据关键码值而直接进行访问的数据结构。也就是说&…

伟大架构师的秘密

By Don Awalt and Rick McUmber RDA Corporation 企业架构师正受到其所面临的大量复杂性的挑战。开发一个能够自动处理企业任务的独立的部门应用程序是一回事。而设计并组成一个支持上万 IT 使用者的满是应用程序、服务器和数据库&#xff08;全都支持多种企业活动&#xff09;…

找出一堆整数中两个元素和为指定值的所有组合

问题描述 5, 5,-7, 5, 9, -1, 5, 1, 9, 4, 6 这堆数中两个数的和为10的组合有:55, 91, 46,如何快速的找出这样的组合&#xff1f; 假定 数组a[]存放元素&#xff0c;数组大小为len_a 指定和为aim 思路一 先排序&#xff0c;low0(最低位置)&#xff0c;uplen_a(最高位置) 当a[lo…

MySQL~数据库基础(常用数据类型、数据库的操作、表的操作)

目录 常用数据类型 数值型(整型、浮点型) 字符串类型 日期类型 数据库的操作 显示当前数据库 创建数据库 使用数据库 删除数据库 表的操作 创建表 查看表 删除表 重点总结 常用数据类型 数值型(整型、浮点型) BIT(M)&#xff1a;大小&#xff1a;M指定位数&am…