Java 枚举类和自定义枚举类和enum声明及实现接口的操作

1.枚举类

注:

JDK1.5之前需要自定义枚举类

JDK 1.5 新增的 enum 关键字用于定义枚举类

若枚举只有一个成员, 则可以作为一种单例模式的实现方式

1.枚举类的属性

1、枚举类对象的属性不应允许被改动, 所以应该使用 private final 修饰

2、枚举类的使用 private final 修饰的属性应该在构造器中为其赋值

3、若枚举类显式的定义了带参数的构造器, 则在列出枚举值时也必须对应的传入参数

2.自定义枚举类

如何自定义枚举类的方法写在注释里

//自定义枚举类
class Season {
 //1.提供类的属性,声明为private final
 private final String seasonName;
 private final String seasonDesc;
 //2.声明为final的属性,在构造器中初始化
 private Season(String seasonName,String seasonDesc) {
 this.seasonName = seasonName;
 this.seasonDesc = seasonDesc;
 }
 //3.通过公共的方法来调用属性
 public final String getSeasonName() {
 return seasonName;
 }
 public final String getSeasonDesc() {
 return seasonDesc;
 }
 //4.创建枚举类的对象:将类的对象声明为public static final
 public static final Season SPRING = new Season("春天", "春暖花开");
 public static final Season SUMMER = new Season("夏天", "夏日炎炎");
 public static final Season FALL = new Season("秋天", "硕果累累");
 public static final Season WINTER = new Season("冬天", "白雪皑皑");

 @Override
 public String toString() {
 return "Season [seasonName=" + seasonName + ", seasonDesc=" + seasonDesc + "]";
 }
 public void show() {
 System.out.println("这个一个季节");
 }
}

Test

public static void main(String[] args) {
 Season spring = Season.SPRING;
 System.out.println(spring);
 spring.show();
 System.out.println(spring.getSeasonName() +" "+spring.getSeasonDesc());
 }
}

3.Enum枚举类

1、必须在枚举类的第一行声明枚举类对象。

2、枚举类和普通类的区别:

①使用 enum 定义的枚举类默认继承了 java.lang.Enum 类

②枚举类的构造器只能使用 private 访问控制符

③枚举类的所有实例必须在枚举类中显式列出(, 分隔 ; 结尾). 列出的实例系统会自动添加 public static final 修饰

3、JDK 1.5 中可以在 switch 表达式中使用Enum定义的枚举类的对象作为表达式, case 子句可以直接使用枚举值的名字, 无需添加枚举类作为限定

4、Dome

interface info{
 void show();
}
//枚举类
enum Season1 implements info{
 SPRING("春天", "春暖花开"){
 public void show() {
 System.out.println("春天在哪里?");
 }
 },
 SUMMER("夏天", "夏日炎炎")
 {
 public void show() {
  System.out.println("生如夏花");
 }
 } ,
 AUTUTO("秋天", "硕果累累")
 {
 public void show() {
  System.out.println("秋天是用来分手的季节");
 }
 },
 WINTER("冬天", "白雪皑皑")
 {
 public void show() {
  System.out.println("冬天里的一把火");
 }
 };

 //1.提供类的属性,声明为private final
 private final String seasonName;
 private final String seasonDesc;
 //2.声明为final的属性,在构造器中初始化
 private Season1(String seasonName,String seasonDesc) {
 this.seasonName = seasonName;
 this.seasonDesc = seasonDesc;
 }
 //3.通过公共的方法来调用属性
 public final String getSeasonName() {
 return seasonName;
 }
 public final String getSeasonDesc() {
 return seasonDesc;
 }

 @Override
 public String toString() {
 return "Season [seasonName=" + seasonName + ", seasonDesc=" + seasonDesc + "]";
 }
// public void show() {
// System.out.println("这个一个季节");
// }
}

Test

常用方法写在注释里面

public class TestEnum {
 public static void main(String[] args) {
 System.out.println("------------enum关键字");
 //1.values():返回枚举类数组
 Season1 [] seasons = Season1.values();
 for(int i = 0; i < seasons.length;i++) {
  System.out.println(seasons[i]);
 }
 //2.valueOf(String name):要求传入的形参name是枚举对象的名字
 //否则:报java.lang.IllegalArgumentException异常
 String str = "SPRING";
 Season1 sea = Season1.valueOf(str);
 System.out.println(sea);
 //线程的运行状态
 Thread.State[] states = Thread.State.values();
 for (int i = 0; i < states.length; i++) {
  System.out.println(states[i]);
 }
 }
}

4.实现接口的枚举类

1、实现接口的枚举类和普通 Java 类一样,枚举类可以实现一个或多个接口

2、若需要每个枚举值在调用实现的接口方法呈现出不同的行为方式, 则可以让每个枚举值分别来实现该方法

3、实现方法可以看上面的demo。

补充:java新特性(枚举,注解,接口定义加强)

一.枚举

1.枚举表达

enum ClassName
{
}

2.枚举的本质:

多例设计模式

3.枚举产生

JKD1.5产生枚举,它只是一种类型的包装:使用enum关键字定义的枚举本质上相当于class定义的类,默认继承java.lang.Enum父类

4.枚举中常见的方法

取得枚举名字:public final String name()

取得枚举序号:public final int ordinal()

取得所有枚举对象:values():返回值类型:Enum[]

5.enum和Enum

enum是一个关键字,使用enum定义的枚举本质上就相当于一个类继承了Enum这个抽象类。

6.枚举中可以定义的结构

可以有属性,构造方法

枚举中包含其他类结构,枚举对象的声明必须放在枚举类的首行

枚举可以实现接口,实现接口后,枚举对象变成接口对象

二.注解(Annotation):JDK1.5新增最常用两大特性。

JDK1.5提供的三大注解:@Override,@Deprecated,@SuppressWarnings

1.准确覆写(@Override):

如果该方法覆写正确,不会有编译错误。如果方法名,参数列表与父类中同名方法不同,则会报错。

public class Person
{
   @Override // 如果该方法覆写正确,不会有编译错误。如果方法名,参数列表与父类中同名方法不同,则会报错。
  public String toString()
  {
  }
}

2.过期处理(@Deprecated):

作用于类和方法上,表示不推荐用户使用此类或方法,但是能正常使用。

@Deprecated
public Void fun() {}

3.压制警告(@SuppressWarnings):

当调用了某些操作可能产生问题的时候会出现警告进行,又不想总提示警告,这个时候可以使用注解压制警告。

三.接口定义加强

JDK8以前:全局变量+抽象方法

JDK8以后:

1.default定义的普通方法,通过对象调用

2.static定义的静态方法,通过接口调用

interface Imessage
{
  public default void fun()   //追加普通方法,有方法体
  {
    System.out.println("Holle IMessage");
  }

  public static IMessage getInstance()  //可以由接口名称直接调用
  {
    return new MessageImp();
  }
  public void print();
}
class MessageImp imlements Imessage
{
  @Override
  public void print()
  {
    System.out.println("Holle MessageImp ");
  }
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。如有错误或未考虑完全的地方,望不吝赐教。

(0)

相关推荐

  • 秒懂Java枚举类型(enum)

    理解枚举类型 枚举类型是Java 5中新增特性的一部分,它是一种特殊的数据类型,之所以特殊是因为它既是一种类(class)类型却又比类类型多了些特殊的约束,但是这些约束的存在也造就了枚举类型的简洁性.安全性以及便捷性.下面先来看看什么是枚举?如何定义枚举? 枚举的定义 上述的常量定义常量的方式称为int枚举模式,这样的定义方式并没有什么错,但它存在许多不足,如在类型安全和使用方便性上并没有多少好处,如果存在定义int值相同的变量,混淆的几率还是很大的,编译器也不会提出任何警告,因此这种方式在枚举

  • Java中枚举类型的一种使用方式

    今天改同事的代码发现同事的代码中有大量的if else语句.很不美观而且可读性太差. 因为需要给前端一个key,value的列表.这个列表写死.然而同事的代码. 放几张图,大家自己感受.我都不知道以后这个api咋维护,新增一个工站,减少一个工站. 果然新的任务新增4个工站,好吧,开始给代码装扮一下. 首先,写一个枚举类. package com.smartflow.common.enumpackage; /** * @author :tao * @date :Created in 2020/8/

  • Jackson优雅序列化Java枚举类过程解析

    1. 前言 在Java开发中我们为了避免过多的魔法值,使用枚举类来封装一些静态的状态代码.但是在将这些枚举的意思正确而全面的返回给前端却并不是那么顺利,我们通常会使用Jackson类库序列化对象为JSON,今天就来讲一个关于使用Jackson序列化枚举的通用性技巧. 2. 通用枚举范式 为了便于统一处理和规范统一的风格,建议指定一个统一的抽象接口,例如: /** * The interface Enumerator. */ public interface Enumerator { /** *

  • Java枚举类型在switch语句正确使用方法详解

    很多人也许会尝试写下这样的代码: ResultStructureEnum type = ResultStructureEnum.valueOf(userType); switch (type) { case ResultStructureEnum.STUDENT: ... break; case ResultStructureEnum.TEACHER: ... break; case ResultStructureEnum.PARENT: ... break; ... } # 这样编译不会通过,

  • Java实现接口的枚举类示例

    本文实例讲述了Java实现接口的枚举类.分享给大家供大家参考,具体如下: 一 点睛 枚举类也可以实现一个或多个接口.与普通类实现一个或多个接口完全一样,枚举类实现一个或多个接口时,也需要实现该接口所包含的方法. 如果需要每个枚举值在调用同一个方法时呈现出不同的行为方式,则可以让每个枚举值分别来实现该方法,每个枚举值提供不同的实现方式,从而让不同枚举值调用同一个方法时具有不同的行为方式. 二 实战 1 代码 GenderDesc.java public interface GenderDesc {

  • Java枚举类使用场景及实例解析

    为什么要用枚举类 什么场景会用到枚举,比如在表示一周的某一天,一年中的四季,这样一组常量的时候我们会用到枚举.在Java引入枚举类之前常用一组int常量来表示枚举,这种方式称为int枚举模式(int enum pattern). private static final int MONDAY = 1; private static final int TUESDAY = 2; private static final int WEDNESDAY = 3; private static final

  • Java枚举类接口实例原理解析

    这篇文章主要介绍了Java枚举类接口实例原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 枚举类可以实现一个或多个接口.与普通类实现接口完全一样,枚举类实现接口时,需要实现该接口所包含的方法. 如果需要每个枚举值在调用同一个方法时呈现不同的行为,则可以让每个枚举值在{...}匿名块中实现自己的业务逻辑. public interface IGradeHandler { String getGrade(String studentName)

  • Java 枚举类和自定义枚举类和enum声明及实现接口的操作

    1.枚举类 注: JDK1.5之前需要自定义枚举类 JDK 1.5 新增的 enum 关键字用于定义枚举类 若枚举只有一个成员, 则可以作为一种单例模式的实现方式 1.枚举类的属性 1.枚举类对象的属性不应允许被改动, 所以应该使用 private final 修饰 2.枚举类的使用 private final 修饰的属性应该在构造器中为其赋值 3.若枚举类显式的定义了带参数的构造器, 则在列出枚举值时也必须对应的传入参数 2.自定义枚举类 如何自定义枚举类的方法写在注释里 //自定义枚举类 c

  • Java kafka如何实现自定义分区类和拦截器

    生产者发送到对应的分区有以下几种方式: (1)指定了patition,则直接使用:(可以查阅对应的java api, 有多种参数) (2)未指定patition但指定key,通过对key的value进行hash出一个patition: (3)patition和key都未指定,使用轮询选出一个patition. 但是kafka提供了,自定义分区算法的功能,由业务手动实现分布: 1.实现一个自定义分区类,CustomPartitioner实现Partitioner import org.apache

  • 浅谈让@Value更方便的Spring自定义转换类

    目录 一.万能的字符串 二.自定义转换类 三.总结 一.万能的字符串 当然,任何时候都可以使用字符串作为属性的值,从配置文件里读取出来,如下: 配置文件内容为: pkslow.admin=larry|18|admin@pkslow.com 通过|分割,分别是名字.年龄和邮箱. 对应属性为: @Value("${pkslow.admin}") private String admin; 使用字符串,总是可以获取,并且不会报错.我们可以在使用属性的时候,再转换成其它Bean. 但这样做有一

  • Springboot JPA 枚举Enum类型存入到数据库的操作

    1.使用JPA 的@Enumerated 注解 ,可以直接将Enum映射到数据库中. 但是value的值只有两种方式选择,一种是使用枚举的序号映射,一种是枚举的名称来映射. public enum EnumType { /** Persist enumerated type property or field as an integer. */ ORDINAL, /** Persist enumerated type property or field as a string. */ STRIN

  • Java中自定义注解类及使用实例解析

    这篇文章主要介绍了Java中自定义注解类并使用过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 在Java框架中,经常会使用注解,而且还可以省很多事,来了解下自定义注解. 注解是一种能被添加到java代码中的元数据,类.方法.变量.参数和包都可以用注解来修饰.注解对于它所修饰的代码并没有直接的影响 先写一个自己的注解类 @Documented //会被javadoc命令识别 @Retention(RetentionPolicy.RUNTI

  • ASP.Net Core中使用枚举类而不是枚举的方法

    前言: 我相信大家在编写代码时经常会遇到各种状态值,而且为了避免硬编码和代码中出现魔法数,通常我们都会定义一个枚举,来表示各种状态值,直到我看到Java中这样使用枚举,我再想C# 中可不可以这样写,今天就分享一下我的感悟. 一.通常我们是这样使用枚举的 (1)switch中使用枚举 public enum EmployeeType { Manager, Servant, AssistantToTheRegionalManager } public class Employee { public

  • java自定义枚举转换器示例

    java自定义枚举转换器 复制代码 代码如下: import org.apache.commons.beanutils.Converter; /** * 自定义枚举转换器 *  *  */public class MyEnumConverter implements Converter { @Override // 将value 转换为 c类型 --- 枚举通用转换器 public Object convert(Class c, Object value) {  String strVal =

  • Java用自定义的类作为HashMap的key值实例

    这是Java中很经典的问题,在面试中也经常被问起.其实很多书或者文章都提到过要重载hashCode()和equals()两个方法才能实现自定义键在HashMap中的查找,但是为什么要这样以及如果不这样做会产生什么后果,好像很少有文章讲到,所以写这么一篇来说明下. 首先,如果我们直接用以下的Person类作为键,存入HashMap中,会发生发生什么情况呢? public class Person { private String id; public Person(String id) { thi

  • Java实现自定义LinkedList类的示例代码

    目录 一.LinkedList和ArrayList 二.自定义LinkedList类(单向链表) 1.实现思路 2.Node结点类 3.size().isEmpty().get(int index) 4.add(Object o) 5.add(int index,Object element) 6.test类 在正式讲解怎么自定义LinkedList类之前,需要再回顾一下之前学过的一些内容,避免跟ArrayList类混淆. 一.LinkedList和ArrayList -- LinkedList

  • Java实现自定义ArrayList类的示例代码

    目录 一.总体实现思路 二.add方法 三.size方法 四.isEmpty方法 五.构造方法 六.ArrayList整体代码 七.Test测试类 之前有接触过Collection中的ArrayList类,类中提供了多种可以操作的方法,但是为什么还需要自定义ArrayList类呢?主要是为了学习其中编写程序时的逻辑思维.,今天将简单的介绍ArrayList里面的add方法.size方法.isEmpty方法. 一.总体实现思路 在自定义ArrayList类时需要提前思考多个方面的内容 1.该Arr

随机推荐