=======================================================================
枚举类创建方式:
方式一:JDK1.5之前需要自定义枚举类。
方式二:JDK1.5新增的enum关键字用于定义枚举类。
什么情况下,用枚举类?
================================================================================
其实和单例模式设计原理一样:
package com.holmes.java06;
public class SeasonTest {
public static void main(String[] args) {
Season spring = Season.SPRING;
System.out.println(spring.toString());
}
}
//方式一:自定义枚举类
class Season{
//1.声明Season对象的属性:因为自己定义的常量,因此必须唯一要用private final修改。
private final String seasonName;
private final String seasonDesc;
//2.私有化类的构造器,并给对象属性赋值
private Season(String seasonName,String seasonDesc){
this.seasonName = seasonName;
this.seasonDesc = seasonDesc;
}
//3.提供当前枚举类的多个对象(就像单例模式,本类不能声明对象,但可以调用方法生成对象):public static final类型!
public static final Season SPRING = new Season(“春天”,“春暖花开”);
public static final Season SUMMER = new Season(“夏天”,“夏日炎炎”);
public static final Season AUTUMN = new Season(“秋天”,“秋高气爽”);
public static final Season WINTER = new Season(“冬天”,“冰天雪地”);
//4.其他诉求1:获取枚举类对象的属性
public String getSeasonName() {
return seasonName;
}
public String getSeasonDesc() {
return seasonDesc;
}
//4.其他诉求2:重写toString()方法
@Override
public String toString() {
return “Season{” +
“seasonName='” + seasonName + ‘’’ +
“, seasonDesc='” + seasonDesc + ‘’’ +
‘}’;
}
}
=========================================================================================
- 定义的枚举类默认继承于java.lang.Enum类。
package com.holmes.java06;
public class SeasonTest {
public static void main(String[] args) {
Season summer = Season.SUMMER;
//我们在没有重写toString()方法时,这里默认调用toString()方法,但返回的结果值不是当前地址,说明这个toString()方法被重写过!
System.out.println(summer);//SUMMER
//我们查看Season类的父类
System.out.println(Season.class.getSuperclass());//class java.lang.Enum
//原因就是因为他继承了enum类,而不是Object,如果时Object返回的就是地址。
}
}
//方式二:使用enum关键字枚举类
enum Season{
//1.提供当前枚举类的对象,多个对象之间用",“隔开,末尾对象用”;"结束。
SPRING(“春天”,“春暖花开”),
SUMMER(“夏天”,“夏日炎炎”),
AUTUMN(“秋天”,“秋高气爽”),
WINTER(“冬天”,“冰天雪地”);
//2.声明Season对象的属性:因为自己定义的常量,因此必须唯一要用private final修改。
private final String seasonName;
private final String seasonDesc;
//3.私有化类的构造器,并给对象属性赋值
private Season(String seasonName,String seasonDesc){
this.seasonName = seasonName;
this.seasonDesc = seasonDesc;
}
//4.其他诉求1:获取枚举类对象的属性
public String getSeasonName() {
return seasonName;
}
public String getSeasonDesc() {
return seasonDesc;
}
}
============================================================================
package com.holmes.java06;
public class SeasonTest {
public static void main(String[] args) {
Season summer = Season.SUMMER;
//1.toString()方法:
System.out.println(summer.toString());
System.out.println(“***************”);
//2.values()方法:
Season[] values = Season.values();
for (int i=0; i < values.length;i++){
System.out.println(values[i]);
}
System.out.println(“********”);
//同样在之前的Thread.State状态也是enum定义的:
Thread.State[] values1 = Thread.State.values();
for (int i=0; i < values1.length;i++){
System.out.println(values1[i]);
}
System.out.println(“***************”);
//3.valueOf(String objName)方法:返回枚举类中对象名是objName的对象
Season winter = Season.valueOf(“WINTER”);
System.out.println(winter);//默认调用toString()方法,还是返回对象名。
//如果没找到,就会报错IllegalArgumentException。
}
}
//方式二:使用enum关键字枚举类
enum Season{
//1.提供当前枚举类的对象,多个对象之间用",“隔开,末尾对象用”;"结束。
SPRING(“春天”,“春暖花开”),
SUMMER(“夏天”,“夏日炎炎”),
AUTUMN(“秋天”,“秋高气爽”),
WINTER(“冬天”,“冰天雪地”);
//2.声明Season对象的属性:因为自己定义的常量,因此必须唯一要用private final修改。
private final String seasonName;
private final String seasonDesc;
//3.私有化类的构造器,并给对象属性赋值
private Season(String seasonName,String seasonDesc){
this.seasonName = seasonName;
this.seasonDesc = seasonDesc;
}
//4.其他诉求1:获取枚举类对象的属性
public String getSeasonName() {
return seasonName;
}
public String getSeasonDesc() {
return seasonDesc;
}
}
========================================================================================
-
情况一:实现接口,enum枚举类实现接口并实现其抽象方法。
-
情况二:每个对象可以给自己单独设置重写方法,如下:
package com.holmes.java06;
public class SeasonTest {
public static void main(String[] args) {
Season summer = Season.SUMMER;
//调用自己单独重写的方法
summer.show();
Season winter = Season.WINTER;
//自己没有定义那就调用共用的重写的方法
winter.show();
}
}
interface Info{
void show();
}
//方式二:使用enum关键字枚举类
enum Season implements Info{
SPRING(“春天”,“春暖花开”){
@Override
public void show() {
System.out.println(“这是一个春天”);
}
},
SUMMER(“夏天”,“夏日炎炎”){
@Override
public void show() {
System.out.println(“这是一个夏天”);
}
},
AUTUMN(“秋天”,“秋高气爽”){
@Override
public void show() {
System.out.println(“这是一个春天秋天”);
}
},
WINTER(“冬天”,“冰天雪地”);
private final String seasonName;
private final String seasonDesc;
private Season(String seasonName,String seasonDesc){
this.seasonName = seasonName;
this.seasonDesc = seasonDesc;
}
public String getSeasonName() {
return seasonName;
}
public String getSeasonDesc() {
return seasonDesc;
}
@Override
public void show() {
//在这的方法代表所有对象默认调用该方法,每个对象也可以自己重写自己的方法。
System.out.println(“春夏秋冬”);
}
}
===============================================================================
像@Test,@Override等都是注解,在代码里注解就是特殊标记。
生成文档相关的注解:
JDK内置的三个基本注解:
注解功能之一:可以实现替代配置文件功能:
@BeforeClass,@AfterClass等等以下注解很常用!!要记住!
=========================================================================
-
注解是从JDK5.0开始的,Java增加了对元数据(MetaData)的支持,也就是Annotation(注解)。
-
他到后面最主要的功能就是代替旧版中所遗留的繁冗代码和XML配置等操作。
============================================================================
@Override注解:重写标志,如果报错或者没有变颜色说明代码有问题!
@Deprecated注解:代表已经过时了,但是还可以用!deprecated英文意思是贬低,强烈反对的意思。
通常是因为所修饰的结构危险或存在更好的选择。
@SuppressWarning抑制编译器警告注解,这个很有意思,它就是用来抑制编译器警告的,说的通俗一点就是用来去除警告的。
@SuppressWarning(“xxx”,“xxx”)它可以携带很多参数,每个参数都有不同作用,例如:"unuse"代表未使用,"rawtypes"代表传参时也要传递带泛型的参数等等。
在eclipse中,我们没有用到的变量属性什么的,它会报黄色线条的警告。
在IDEA中,他没有黄色警告,但是它是淡黑的,告诉你没有用到该变量。
同样,我们添加抑制编译器注解后,他就变成正常颜色了。
======================================================================
创建时,要选择Annotation注解类型:
注解的声明就是@interface:
注意:注解和interface接口没有任何关系,@interface就是这么个结构。
自定义注解自动继承了java.lang.annotation.Annotation接口。
内部定义成员,通常使用value表示:
参数名 = “参数值” 形式:
可以指定成员的默认值,使用default定义:
如果自定义注解没有成员,表明是一个标识作用。
就像标识接口差不多,都是标识作用:
当然,相反如果注解有成员,在使用注解时,需要指定成员的值。
自定义注解必须配上注解的信息处理流程(使用反射)才有意义。
==========================================================================
- **JDK的元Annotation(注解)用于修饰其他Annotation(注解)定义的。
简而言之,就是修饰其他注解的注解叫元注解。**
同样还有一个叫做元数据:
- JDK提供的4中元注解:
@Retention元注解:指定所修饰的Annotation的生命周期:SOURCE、CLASS(默认)、RUNTIME(只有声明为RUNTIME生命周期的注解,才能通过反射获取。)
source:注解只保留在源文件,当Java文件编译成class文件的时候,注解被遗弃;被编译器忽略
class:注解被保留到class文件,但jvm加载class文件时候被遗弃,这是默认的生命周期
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
@Retention元注解:指定所修饰的Annotation的生命周期:SOURCE、CLASS(默认)、RUNTIME(只有声明为RUNTIME生命周期的注解,才能通过反射获取。)
source:注解只保留在源文件,当Java文件编译成class文件的时候,注解被遗弃;被编译器忽略
class:注解被保留到class文件,但jvm加载class文件时候被遗弃,这是默认的生命周期
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-HmL74FLQ-1715704565545)]
[外链图片转存中…(img-IHMF2PVK-1715704565546)]
[外链图片转存中…(img-wJ7cjTrm-1715704565546)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!