网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
▷ 不需要提供setXxx方法,因为枚举对象值通常为只读
▷ 对枚举对象、属性使用 final + static 共同修饰,实现底层优化
▷ 枚举对象名通常全部大写,遵循常量命名的规范
▷ 枚举对象根据需要,可以有多个属性
☣2、代码示例
package advanced.little_project.project02; public class case223 { public static void main(String[] args) { //因为是静态方法所以直接调用 System.out.println(Season.AUTUMN); System.out.println(Season.SPRING); } } //class类 class Season { private String name; //在 Season 内部,直接创建固定的对象 , //优化,可以加入 final 修饰符 public static final Season SPRING = new Season("春天"); public static final Season WINTER = new Season("冬天"); public static final Season AUTUMN = new Season("秋天"); public static final Season SUMMER = new Season("夏天"); //将构造器私有化,为了防止直接 new private Season(String name) { this.name = name; } //去掉 setXxx 方法, 防止属性被修改,只保留getXxx方法,用于读取 public String getName() { return name; } //重写toString()方法,用于输出 @Override public String toString() { return "Season{" + "name='" + name + '}'; } }
☣3、代码分析
▶ **注意:**自定义类枚举,创建的类是class 类,比如代码中的:class Season { }
▶ 自定义枚举的一般思路:
▷ 写属性:私有化
▷ 写构造器:将构造器私有化,为了防止直接 new
▷ 写getXxx方法:去掉 setXxx 方法, 防止属性被修改,只保留getXxx方法,用于读取
▷ 重写toString()方法,用于输出
▷ 在自定义枚举的内部,直接创建固定的对象 ,
▷ 可以加入 final 修饰符进行优化
☣☣三、enum关键字实现枚举
☣1、enum使用细节
① 我们使用 enum 关键字定义一个枚举类时,默认会继承 java.lang.Enum 类, 而且是一个 final 类,如图:
② 自定义枚举类的写法:
public static final Season2 SPRING = new Season2(“春天”)③ enum关键字实现枚举的写法:
SPRING(“春天”)④ 如果使用无参构造器创建枚举对象,则实参列表和小括号都可以省略
⑤ 当有多个枚举对象时,使用 “,” 间隔,最后有一个分号结尾
⑥
枚举对象必须放在枚举类的行首☣2、enum实现接口
▷ 使用enum关键字后,就不能再继承其他类了,因为enum会隐式继承Enum,而Java是单继承机制
▷ 枚举类和普通类一样,可以实现接口,形式:enum 类名 implements 接口1,接口2{}
☣3、代码示例
package advanced.little_project.project02; public class case223 { public static void main(String[] args) { //因为是静态方法所以直接调用 System.out.println(Season.AUTUMN); System.out.println(Season.SPRING); } } //定义enum关键字实现枚举 enum Season { //枚举对象必须放在枚举类的行首 SPRING("春天"),WINTER("冬天"),AUTUMN("秋天"),SUMMER("夏天"); private String name; //将构造器私有化,为了防止直接 new private Season(String name) { this.name = name; } //去掉 setXxx 方法, 防止属性被修改,只保留getXxx方法,用于读取 public String getName() { return name; } //重写toString()方法,用于输出 @Override public String toString() { return "Season{" + "name='" + name + '}'; } }
四、enum常用方法
1、常用方法表
方法名 详细描述 valueOf 传递枚举类型的Class对象和枚举常量名称給静态方法valueOf,会得到与参数匹配的枚举常量。 toString 得到当前枚举常量的名称。你可以通过重写这个方法来使得到的结果更易读。 equals 在枚举类型中可以直接使用“"来比较两个枚举常量是否相等。Enum提供的这个equals0方法,也是直接使用“”实现的。它的存在是为了在Set、List 和Map中使用。注意,equals()是不可变的。 hashCode 实现了hashCode0来和equals0保持- - 致。它也是不可变的。 getDeclaringClass 得到枚举常量所属枚举类型的Class对象。可以用它来判断两个枚举常量是否属于同一一个枚举类型。 name 得到当前枚举常量的名称。建议优先使用toString0 ordinal 得到当前枚举常量的次序。 compareTo 枚举类型实现了Comparable接口,这样可以比较两个枚举常堂的大小(按照声明的顺序排列)。 clone 枚举类型不能被Cloneo为了防止子类实现克隆方法,Enum 实现了一个仅抛出CloneNotSupportedException异常的不变Clone0。 values 返回枚举类中所有的值。 2、常见方法演示:代码示例
首先定义一个enum Weekday 类:
enum Weekday { MONDAY("星期一"), TUESDAY("星期二"), Week("星期三"), THURSDAY("星期四"), FIRDAY("星期五"), STAURDAY("星期六"), SUNDAY("星期日"); private String name; private Weekday(String name) { this.name = name; } @Override public String toString() { return name; } }
1、name 方法:
//name 得到当前枚举常量的名称,建议优先使用toString() System.out.println(Weekday.MONDAY.name()); System.out.println(Weekday.STAURDAY.name());
2、toString 方法:
//toString 得到当前枚举常量的名称 System.out.println(Weekday.MONDAY.toString()); System.out.println(Weekday.STAURDAY.toString());
3、ordinal 方法:
//ordinal()输出的是该枚举对象的次序/编号,从0开始编号 Weekday monday = Weekday.MONDAY; System.out.println(monday.ordinal()); //MONDAY枚举对象是第一个,因此输出0
4、values 方法:
//values 方法 Weekday[] all = Weekday.values(); for(Weekday c : all){ System.out.println(c); }
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
System.out.println©;
}
[外链图片转存中…(img-1xCZynnQ-1715881962639)]
[外链图片转存中…(img-Eoc46E3d-1715881962640)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新