Java 枚举 (enum) 使用方法

Java 枚举 (enum) 使用方法什么是枚举 枚举类型是 Java5 中新增特性的一部分 它是一个特殊的 class 这个 class 相当于 finalstatic 修饰 不能被继承 所有的枚举都继承自 java lang Enum 类 由于 Java 不支持多继承 所以枚举对象不能再继承其他类 在没有枚举类型时定义常量常见的方式 Createdbyzej 5 7 Blog http blog csdn net javazejian 原文地址 请尊重原创 使用普通方式定义日期常量


什么是枚举?

枚举类型是Java 5中新增特性的一部分,它是一个特殊的class,这个class相当于final static修饰,不能被继承。所有的枚举都继承自java.lang.Enum类。由于Java 不支持多继承,所以枚举对象不能再继承其他类。

在没有枚举类型时定义常量常见的方式

/ * Created by zejian on 2017/5/7. * Blog : http://blog.csdn.net/javazejian [原文地址,请尊重原创] * 使用普通方式定义日期常量 */ public class DayDemo { 
     public static final int MONDAY =1; public static final int TUESDAY=2; public static final int WEDNESDAY=3; public static final int THURSDAY=4; public static final int FRIDAY=5; public static final int SATURDAY=6; public static final int SUNDAY=7; } 

上述的常量定义常量的方式称为int枚举模式,这样的定义方式并没有什么错,但它存在许多不足,如在类型安全和使用方便性上并没有多少好处,如果存在定义int值相同的变量,混淆的几率还是很大的,编译器也不会提出任何警告,因此这种方式在枚举出现后并不提倡,现在我们利用枚举类型来重新定义上述的常量:

//枚举类型,使用关键字enum enum Day { 
     MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY, SUNDAY } 

使用方法

1、枚举型常量

//它的构造方法强制被私有化,下面有一个默认的构造方法private ColorEnum(); public enum ColorEnum { 
      //每个枚举变量都是枚举类ColorEnum的实例,相当于RED=new ColorEnum(1),按序号来。 //每个成员变量都是final static修饰 RED, GREEN, BLANK, YELLOW; } 

测试:

@org.junit.Test public void ColorTest() { 
      //ordinal返回枚举变量的序号 for(ColorEnum color:ColorEnum.values()) { 
      System.out.println(color+",ordinal:"+color.ordinal()+",name:"+color.name()); } } 

2、带参枚举

public enum TypeEnum { 
       FIREWALL("firewall"), SECRET("secretMac"), BALANCE("f5"); private String typeName; TypeEnum(String typeName) { 
       this.typeName = typeName; } / * 根据类型的名称,返回类型的枚举实例。 * * @param typeName 类型名称 */ public static TypeEnum fromTypeName(String typeName) { 
       for (TypeEnum type : TypeEnum.values()) { 
       if (type.getTypeName().equals(typeName)) { 
       return type; } } return null; } public String getTypeName() { 
       return this.typeName; } } 

测试:

@org.junit.Test public void TypeTest() { 
       String typeName = "f5"; TypeEnum type = TypeEnum.fromTypeName(typeName); //type:是TypeEnum类实例化对象 typeName:实例化对象type的值  // ordinal:实例化对象type的序号(int) 排序值(默认自带的属性 ordinal 的值) //name:实化对象的名字(String) 枚举名称(即默认自带的属性 name 的值) System.out.println(type+",typeName:"+type.getTypeName()+",ordinal:"+type.ordinal()+",name:"+type.name()); } 

3、枚举里添加方法

public enum SeasonEunm { 
        //每一个枚举变量都是枚举类SeasonEunm的实例化 //SeasonEunm.SPRING获得的对象相当于new SeasonEunm("春","春困");获得的对象 SPRING("春","春困"),SUMMER("夏","夏睡"),AUTUMN("秋","秋乏"),WINTER("冬","冬眠"); //强制私有化的构造方法,因为枚举类默认继承Eunm类,被final static修饰,不能被继承 //由于被强制private,所以不能使用new去生成枚举对象 //在SeasonEunm.SPRING获得对象,隐式调用了下面的构造方法 // 构造方法 ,赋值给成员变量 private SeasonEunm(String name, String value) { 
        this.name = name; this.value = value; } //添加成员变量的原因是,方便够着方法赋值,使用SeasonEunm.SPRING.getName就能获取对应的值 private String name; private String value; public String getName() { 
        return name; } public void setName(String name) { 
        this.name = name; } public String getValue() { 
        return value; } public void setValue(String value) { 
        this.value = value; } } 

测试:

@org.junit.Test public void SessionTest() { 
         //ordinal返回枚举变量的序号 for(SeasonEunm seasion:SeasonEunm.values()) { 
         System.out.println(seasion+",ordinal:"+seasion.ordinal()+",name:"+seasion.name()); System.out.println("枚举变量值:"+seasion.getName()+",枚举变量值:"+seasion.getValue()); } } 

4、覆盖枚举方法

package com.yang; public enum RGBEnum { 
         RED("红色", 1), GREEN("绿色", 2), BLANK("白色", 3), YELLO("黄色", 4); // 成员变量  private String name; private int index; // 构造方法 ,赋值给成员变量 private RGBEnum(String name, int index) { 
         this.name = name; this.index = index; } //覆盖方法 :只能使用toString方法来输出枚举变量值 @Override public String toString() { 
         return this.index+"_"+this.name; } } 

测试:

@org.junit.Test public void RGBEnumTest() { 
         for(RGBEnum rgb:RGBEnum.values()) { 
         System.out.println(rgb.toString()); } } 

以上是枚举使用方法的简单介绍,如果要深入学习了解,推荐一篇不错的文章:

深入理解Java枚举类型(enum)







版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233148.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Microsoft Platform SDK 选择及在vc++6.0中的配置

    Microsoft Platform SDK 选择及在vc++6.0中的配置MicrosoftPlatformSDK选择及在vc++6.0中的配置转自http://hi.baidu.com/reddragon1314/blog/item/c6782188f00905

    2022年7月2日
    43
  • 51单片机流水灯电路以及C代码「建议收藏」

    51单片机流水灯电路以及C代码「建议收藏」流水灯是51单片机的入门级实验,以下是其电路图以及C代码流水灯proteus电路图此图发光二极管采用共阳极式连接流水灯C代码#include<reg51.h>voiddelay1s(unsignedcharn);voidMovinglight(){ unsignedcharcodeMovinglightA

    2022年5月3日
    61
  • 学习Altas 笔记[JS简单调用服务端方法]

    学习Altas 笔记[JS简单调用服务端方法]nbsp nbsp nbsp nbsp nbsp 在 Ajax 框架中 Asp net 方面最强当属 Altas 最强 以前使用 AjaxPro Net 和 MagicAjax 最几个都比较好用 这几个月来 Altas 已经进入 CTP 版本 是开始学习研究 Altas 的时机了 准备利用 Altas 为 http www yupsky com nbsp 开发成员之间在线通讯的类似于 MSN 这样的功能 今天初步的学习了一下 Altas 最基础的学习内容就是使用 ja

    2025年9月19日
    3
  • java中级面试题1

    java中级面试题11、threadlocal问题https://blog.csdn.net/tiwerbao/article/details/50827305ThreadLocal源码可以看出:1)      ThreadLocal赋初始值的时候,需要在线程运行中,即run()中,不能作为thread的属性,否则ThreadLocalMap会挂错线程;2)      使用ThreadLocal隔离的值不能是引用,否…

    2022年10月11日
    2
  • PLD- FPGA与CPLD的区别[通俗易懂]

    PLD- FPGA与CPLD的区别[通俗易懂]http://home.eeworld.com.cn/my/space.php?uid=170289&do=blog&id=31215FPGA与CPLD的区别多篇整合系统的比较,与大家共享:尽管FPGA和CPLD都是可编程ASIC器件,有很多共同特点,但由于CPLD和FPGA结构上的差异,具有各自的特点:①CPLD更适合完成各种算法和组合逻辑,FPGA更适合于完成时序逻辑

    2022年5月27日
    40
  • 如何用 JavaScript 下载文件

    如何用 JavaScript 下载文件简介我们知道,下载文件是一个非常常见的需求,但由于浏览器的安全策略的限制,我们通常只能通过一个额外的页面,访问某个文件的url来实现下载功能,但是这种用户体验非常不好。幸好,HTML5里面为  标签添加了一个 download 的属性,我们可以轻易的利用它来实现下载功能,再也不需要用以前的笨办法了。原理我们先看看 download 的使用方法:

    2022年5月6日
    46

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号