枚举类的使用
- 一、枚举类的使用
-
- 枚举类的理解:类的对象只有有限个,确定的。
-
- 当需要定义一组常量时,强烈建议使用枚举类
-
- 如果一个枚举类中只有一个对象,则可以作为单例模式的实现方式
- 二、如何定义枚举类
- 方式一:5.0之间,自定义枚举类
- 方式二:5.0时,可以使用enum关键字定义枚举类
- 三、Enum类中的常用方法
- 1、values(): 返回枚举类型的对象数组
-
- valueOf(String obj):可以把一个字符串转化为对应的枚举类型
-
- toString():返回当前枚举类对象常量的名称
- 四、使用enum关键字定义枚举类实现接口的情况
- 情况一:实现接口,在enum类中实现抽象方法
- 情况二:让枚举类对象分别实现抽象方法
public class SeasonTest {
public static void main(String[] args) {
Season spring=Season.SPRING;
System.out.println(spring.toString());
}
}
//自定义枚举类
class Season{
//1. 声明Season对象的属性
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("夏天","xia");
public static final Season AUTUMN=new Season("秋天","qiu");
public static final Season WINTER=new Season("冬天","dong");
//4. 其他诉求:获取属性
public String getSeasonName() {
return seasonName;
}
public String getSeasonDesc() {
return seasonDesc;
}
@Override
public String toString() {
return "Season{" +
"seasonName='" + seasonName + '\'' +
", seasonDesc='" + seasonDesc + '\'' +
'}';
}
}
public class SeasonTest1 {
public static void main(String[] args) {
Season1 summer=Season1.SUMMER;
// toString()
System.out.println(summer.toString());
// values()
Season1[] values = Season1.values();
for (int i = 0; i < values.length; i++) {
System.out.println(values[i]);
}
// valueOf(): 返回枚举类中对象名是objName的对象
// 如果没有则抛异常
Season1 winter=Season1.valueOf("WINTER");
System.out.println(winter);
}
}
interface info{
void show();
}
enum Season1 implements info{
//1. 提供当前枚举类的对象,多个对象之间用,隔开,末尾用;
SPRING("春天","春暖花开"){
@Override
public void show() {
System.out.println("spring");
}
},
SUMMER("夏天","xia"){
@Override
public void show() {
System.out.println("summer");
}
},
AUTUMN("秋天","qiu"){
@Override
public void show() {
System.out.println("autumn");
}
},
WINTER("冬天","dong"){
@Override
public void show() {
System.out.println("winter");
}
};
//1. 声明Season对象的属性
private final String seasonName;
private final String seasonDesc;
//2. 私有化构造器,并给对象属性赋值
private Season1(String seasonName,String seasonDesc){
this.seasonName=seasonName;
this.seasonDesc=seasonDesc;
}
//4. 其他诉求:获取属性
public String getSeasonName() {
return seasonName;
}
public String getSeasonDesc() {
return seasonDesc;
}
// @Override
// public String toString() {
// return "Season{" +
// "seasonName='" + seasonName + '\'' +
// ", seasonDesc='" + seasonDesc + '\'' +
// '}';
// }
// @Override
// public void show() {
// System.out.println("this is a season");
// }
}
注解的使用
框架=注解+反射+设计模式
/**
* 注解的使用:
* 1. 理解Annotation:5.0新增;代码里的特殊标记,可以在编译,类加载,运行时被读取,并在
* 程序员可以在不改变原有逻辑的情况下,在源文件嵌入一些补充信息
* 2.Annotation的使用示例
* 示例一:生成文档相关的注解:@author
* 示例二:在编译时进行格式检查
* @Override:
* @deprecated: 修饰元素已过时,有更好的选择
* @suppressWarnings: 抑制编译器警告
*
* 3.如何自定义注解
* 1. 注释声明为:@interface
* 2. 内部定义成员,通常使用value表示
* 3. 可以指定成员的默认值,使用default定义
* 4. 如果自定义注解没有成员,表明是一个标识作用
*
* 如果有成员,在使用注解时,需要指明成员的值
* 自定义注解通常都会指明两个元注解:Retention,Target
*
* 4.JDK中的4种元注解:修饰其他注解的注解
* Retention: 指定所修饰的Annotation的生命周期:SOURCE\CLASS(默认行为)\RUNTIME
* 只有声明为RUNTIME生命周期的注解,才能通过反射获取
* Target: 用于指定被修饰的Annotation能用于修饰哪些程序元素
* ***下面两个少用***
* Documented: 表示所修饰的注解在被javadoc解析时,保留下来
* Inherited: 被它修饰的Annotation具有继承性
*
* 5.通过反射获得注解信息
*
* 6.jdk8中注解的新特性:可重复注解,类型注解
* 1.可重复注解:(1)在MyAnnotation(自己定义的)上声明@Repeatable,成员值为MyAnnotations.class
* (2)MyAnnotation的Target和Retention等元注解和MyAnnotations相同
* 2.类型注解:
* ElementType.TYPE_PARAMETER 表示该注解能写在类型变量的声明语句中(如泛型声明)
* ElementType.TYPE_USE 表示该注解能写在使用类型的任何语句中