【Java系列】深入解析枚举类型

序言

即便平凡的日子仿佛毫无波澜,但在某个特定的时刻,执着的努力便会显现出它的价值和意义。

希望这篇文章能让你不仅有一定的收获,而且可以愉快的学习,如果有什么建议,都可以留言和我交流

问题

思考一下这寄个问题,我们将围绕这三个问题来开始学习:

  • 什么是枚举
  • 怎么定义枚举
  • 枚举的使用场景

1 什么是枚举  

Java 枚举(Enum)是一种特殊的数据类型,它是一组预定义的常量,每个常量都有一个名称和一个值。

枚举类型在 Java 中被广泛使用,它可以用来代替常量、标志位、状态码等,使代码更加清晰、易读和易维护。

下面是 Java 枚举的详细介绍。

2 枚举的使用

定义枚举类型

在 Java 中,可以通过关键字 enum 来定义枚举类型。枚举类型的定义格式如下:

enum EnumName {
    Constant1,
    Constant2,
    Constant3,
    ...
}

其中 EnumName 是枚举类型的名称,Constant1Constant2Constant3 等是枚举类型的常量。每个枚举常量都有一个名称和一个值,枚举常量的名称通常采用大写字母命名,多个单词之间用下划线分隔。

访问枚举常量

在 Java 中,可以通过枚举类型的名称来访问枚举常量。例如,假设有一个名为 Weekday 的枚举类型,可以通过如下方式来访问枚举常量:

Weekday monday = Weekday.Monday;

这里的 Weekday.Monday 表示 Weekday 枚举类型中的 Monday 常量。

枚举方法

枚举类型可以定义方法,这些方法可以在枚举常量上调用。例如,可以在 Weekday 枚举类型中定义一个 isWeekend 方法来判断当前枚举常量是否为周末:

enum Weekday {
    Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday;

    public boolean isWeekend() {
        return this == Saturday || this == Sunday;
    }
}

在上面的例子中,通过在枚举常量后面定义方法,可以在每个枚举常量上调用这个方法。例如,可以通过 Weekday.Saturday.isWeekend() 来判断 Saturday 是否为周末。

枚举构造器

枚举类型也可以定义构造器,这些构造器只能在枚举常量的定义中被调用,并且只能用来初始化枚举常量的值。例如,可以在 Weekday 枚举类型中定义一个带参数的构造器来设置枚举常量的值:

enum Weekday {
    Monday("星期一"), Tuesday("星期二"), Wednesday("星期三"), Thursday("星期四"), Friday("星期五"), Saturday("星期六"), Sunday("星期日");

    private String value;

    private Weekday(String value) {
        this.value = value;
    }

    public String getValue() {
        return value;
    }
}

在上面的例子中,通过在枚举常量后面定义构造器,可以在枚举常量的定义中为枚举常量设置值。例如,可以通过 Weekday.Monday.getValue() 来获取 Monday 的值。

枚举实现接口

枚举类型也可以实现接口,这样每个枚举常量都会自动实现接口中的方法。例如,可以在 Weekday 枚举类型中定义一个接口,并让枚举类型实现这个接口:

interface Printable {
    void print();
}

enum Weekday implements Printable {
    Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday;

    @Override
    public void print() {
        System.out.println("Today is " + this.name());
    }
}

在上面的例子中,通过让 Weekday 枚举类型实现 Printable 接口,使得每个枚举常量都自动实现了 print 方法。例如,可以通过 Weekday.Monday.print() 来输出当前是星期几。

总结

总之,Java 枚举是一种强类型的数据类型,它提供了一种更加优雅、清晰和类型安全的方式来表示常量、状态码等。

枚举类型可以定义常量、方法、构造器和实现接口,这使得枚举类型非常灵活和功能强大。枚举类型在 Java 中的使用非常广泛,尤其在表示状态、选项等方面,可以极大地提高代码的可读性和易维护性。

2 案例

假设我们有一个游戏,游戏中有三个角色:战士、法师和牧师。每个角色都有自己的属性:血量、攻击力和防御力。

我们可以使用枚举类型来表示这三个角色,代码如下:

定义角色枚举 

public enum Role {
    WARRIOR("战士", 100, 50, 30),
    MAGE("法师", 80, 70, 20),
    PRIEST("牧师", 60, 30, 50);

    private String name; // 角色名称
    private int hp; // 角色血量
    private int attack; // 角色攻击力
    private int defense; // 角色防御力

    // 构造方法
    private Role(String name, int hp, int attack, int defense) {
        this.name = name;
        this.hp = hp;
        this.attack = attack;
        this.defense = defense;
    }

    // getter方法
    public String getName() {
        return name;
    }

    public int getHp() {
        return hp;
    }

    public int getAttack() {
        return attack;
    }

    public int getDefense() {
        return defense;
    }
}

在上面的代码中,我们定义了一个名为Role的枚举类型,其中包含了三个枚举常量:WARRIOR、MAGE和PRIEST。每个枚举常量都有自己的属性:名称、血量、攻击力和防御力。我们还定义了一个构造方法,用于初始化这些属性。最后,我们为每个属性定义了getter方法,以便其他类可以访问这些属性。

 定义角色

现在,我们可以在其他类中使用Role枚举类型来表示游戏中的角色。例如,我们可以编写一个Player类来表示游戏中的玩家,代码如下:

public class Player {
    private Role role; // 玩家角色

    public Player(Role role) {
        this.role = role;
    }

    public void attack(Player target) {
        int damage = this.role.getAttack() - target.getRole().getDefense();
        if (damage > 0) {
            int newHp = target.getRole().getHp() - damage;
            target.getRole().setHp(newHp);
        }
    }

    public Role getRole() {
        return role;
    }

    public void setRole(Role role) {
        this.role = role;
    }
}

在上面的代码中,我们定义了一个名为Player的类,用来表示游戏中的玩家。每个玩家都有一个角色,我们使用Role类型的role字段来表示。在Player类的构造方法中,我们需要传入一个Role类型的参数来初始化玩家的角色。

Player类还有一个attack方法,用来实现玩家的攻击操作。在这个方法中,我们通过调用getAttack和getDefense方法来获取玩家的攻击力和防御力,然后计算出攻击造成的伤害。如果伤害值大于0,就更新目标玩家的血量。Player类还有一些getter和setter方法,用来访问和修改玩家的角色。

测试

现在,我们可以编写一个简单的测试类来测试上面的代码,代码如下:

public class GameTest {
    public static void main(String[] args) {
        Player player1 = new Player(Role.WARRIOR);
        Player player2 = new Player(Role.MAGE);

        System.out.println("玩家1选择了" + player1.getRole().getName());
        System.out.println("玩家2选择了" + player2.getRole().getName());

        player1.attack(player2);

        System.out.println("玩家2的血量为:" + player2.getRole().getHp());
    }
}

在上面的代码中,我们创建了两个玩家,一个选择了战士角色,另一个选择了法师角色。然后,我们让玩家1攻击玩家2,并输出玩家2的血量。运行这个测试类,输出结果如下:

玩家1选择了战士
玩家2选择了法师
玩家2的血量为:60

从输出结果可以看出,玩家1的攻击对玩家2造成了伤害,玩家2的血量减少了攻击力减去防御力得到的伤害值,变成了60。

总结 

总的来说,这个案例中使用了枚举类型来表示游戏中的角色,每个角色都有自己的属性,并且可以在其他类中使用枚举类型来表示角色。通过这个案例,我们可以看到Java中枚举类型的使用非常灵活,可以用来表示任何有限的常量集合。

图书推荐

Java28岁了,当打之年,并且还会打很多年。

为即将或正在使用Java的你推荐Java“此生错过必遗憾”系列书单。看看你还缺哪本?请补齐。

图书列表:

  • Java核心技术第12版开发基础+高级特性(套装共2册)
  • Java核心技术第11基础知识+高级特性(套装共2册)
  • Java编程思想[Thinking in Java]
  • Effective Java 中文版(原书第3版)
  • Java语言程序设计基础篇+进阶篇(原书第12版)(套装共2册)
  • Java并发编程实战
  • 软件架构实践(原书第4版)

Java核心技术第12版开发基础+高级特性(套装共2册)

Java四大名著之一Core Java最新版,一键打包全套2册!建议入门小白和准备升级到Java17的开发者购买。本书根据Java17新特性全面升级!赠送作者亲授视频课+海量代码集。

可先睹为快:《Java核心技术第12版开发基础+高级特性(套装共2册)》

 Java核心技术第11基础知识+高级特性(套装共2册)

“Java四大名著”之一Core Java次新版,一键打包全套2册!建议实际生产环境仍在使用Java8、Java11开发且暂时没有升级版本打算的开发者购买。本书基于Java9-11编写,赠送作者亲授视频课+海量代码集。

先睹为快:《Java核心技术 卷1 基础知识+Java核心技术 卷2 高级特性(原书第11版)

Java编程思想[Thinking in Java]

“Java四大名著”之一需要有一定编程基础的人才可阅读,即使很多内容还无法理解,但每次读完一定会有所收获。本书单最前面推荐的《Java核心技术》侧重技术,而《Java编程思想》侧重于“思想”,本书为你剖析Java中各个内容的设计理念。这是一本伴随我们技术成长的好书,买一本放在旁边,摸着就有底气。

限时秒杀链接:《Java编程思想(第4版)》

 

Effective Java 中文版(原书第3版)

Java之父James Gosling

“我很希望我10年前就能拥有这本书。有人可能认为我不需要任何Java方面的书籍,但是我需要这本书。”

“Java四大名著”之一适合已经掌握Java核心技术的程序员,想更加深入地了解Java编程语言的开发者阅读。针对如何编写高效、设计优良的程序提出了最实用、最权威的指导方针,通过90条简短、独立的经验法则,探索新的设计模式和语言习惯用法,帮你更加有效地使用Java编程语言及其基本类库,指引你少走弯路。这些经验规则涵盖了大多数开发人员每天所面临的问题的解决方案。是Java开发人员案头上的一本不可或缺的参考书。

限时秒杀链接:《Effective Java中文版(原书第3版)》

 

Java语言程序设计基础篇+进阶篇(原书第12版)(套装共2册)

书相较于《Java核心技术》更加的基础,如果你阅读《Java核心技术》有些吃力,建议从本书读起。畅销20余年的“长城书”一键打包全套!被世界各地的大学选作教材,更新至Java9、10和11。本书通过示例讲解问题求解技巧,提供大量的程序清单,每章配有丰富的复习题和编程练习题,帮助读者掌握编程技术并解决实际开发中遇到的问题。

限时秒杀链接:《Java语言程序设计基础篇+进阶篇(原书第12版)(套装共2册)》

Java并发编程实战

让注重实战的你更快领悟Java并发编程的要领,快速构建大规模并发应用程序。“Java四大名著”之一《Effective Java》的作者Joshua Bloch参与编写。本书是Java并发编程领域的里程碑著作!从并发编程的基本理论入手,逐步介绍了在设计Java并发程序时各种重要的设计原则、设计模式与思维模式。另一本蚂蚁金服方腾飞老师写的《Java并发编程的艺术》也适合一并阅读。

限时秒杀链接:《Java并发编程实战》

 

软件架构实践(原书第4版)

让你少走弯路的进阶架构师避坑指南!图书届奥斯卡Jolt大奖双冠王作品!全球10余个国家出版。卡内基梅隆等名校教材,IEEE杂志10佳图书,软件架构图书事实标准。

限时秒杀链接:《软件架构实践(原书第4版)》

参与方式

图书数量:本次送出 5 本   !!!⭐️⭐️⭐️
活动时间:截止到 2023-05-29 12:00:00

抽奖方式:

  • 3本,留言+该留言论赞数的前三名各获得一本!
  • 2本,评论区随机挑选小伙伴!
  • 留言内容:“祝Java28岁生日快乐!。+【你想要的书名】”


参与方式:关注博主、点赞、收藏,评论区留言 

中奖名单 

🍓🍓 获奖名单🍓🍓

 中奖名单:请关注博主动态

名单公布时间:2023-05-29 下午

中奖:

1.熬夜磕代码

2.YoLo

3.署前街的少年

4.就要吃苹果

5.JavaLearnerZGQ

请以上中奖小伙伴,及时联系博主

  • 115
    点赞
  • 157
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 96
    评论
Java中,前端传递的枚举类型可以通过使用`@RequestBody`注解接收的类中对应的枚举来进行转换。具体实现方式如下所示: 首先,定义一个枚举类,例如`SeasonEnum`,在该枚举类中使用`@JsonFormat(shape = JsonFormat.Shape.OBJECT)`注解来指定序列化的格式。然后在枚举类中定义各个枚举值,并通过私有构造函数设置对应的值和名称。同时,可以使用`@JsonCreator`注解和`getByValue`静态方法来根据值获取对应的枚举值。 接着,在接收数据的类中,比如`TestEnum`和`CooAccountDto`中,可以定义一个枚举类型的属性,例如`private SeasonEnum season;`。然后在对应的getter和setter方法上添加`@JsonFormat(shape = JsonFormat.Shape.OBJECT)`注解。 最后,在后端的接口方法上使用`@PostMapping`注解指定请求路径,并接收一个`TestEnum`对象作为参数。在方法内部,可以通过`testEnum.getSeason()`获取前端传递的枚举类型,并进行后续的操作。 以上就是将Java前端传递的枚举类型转换为后端枚举类型的方式。通过以上步骤,可以方便地在前后端之间进行枚举类型的传递和转换。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* [前端传输json数据,后端如何用枚举接受](https://blog.csdn.net/weixin_66521221/article/details/123113399)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [前端传值后端枚举接收](https://blog.csdn.net/Json_Marz/article/details/119248493)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 96
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

颜淡慕潇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值