【Java 14】枚举类、注解

25 篇文章 0 订阅
20 篇文章 0 订阅

一 枚举类

1 枚举类的使用

image-20200821162616671

image-20200821162631908

  1. 枚举类的理解:类的对象只有有限个,确定的。我们称此类为枚举类
  2. 当需要定义一组常量时,强烈建议用枚举类
  3. 如果枚举类只有一个对象,则可以作为单例模式的实现方式

2 枚举类的定义

2.1 自定义枚举类(JDK5.0之前)

image-20200821175315357

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 Season SPRING = new Season("春天""1");
    public static final Season SUMMER = new Season("夏天""2");
    public static final Season AUTUMN = new Season("秋天""3");
    public static final Season WINTER = new Season("冬天""4");
    
    //4.其他诉求1:获取枚举类对象的属性
    public String getSeasonName(){
        return seasonName;
    }
    public String getSeasonDesc(){
        return seasonDesc;
    }
    
    //4.其他诉求2:提供toString()
    public String toString(){
        return ----
    }
    
}

Season spring = Season.SPRING;
System.out.println(spring);

2.2 使用enum定义枚举类(JDK5.0)

定义的枚举类默认继承于java.lang.Enum类

image-20200821175325869

enum Season{
    
    //1.提供当前枚举类的对象,多个对象之间用","隔开,末尾对象";"结束
    SPRING("春天""1"),
    SUMMER("夏天""2"),
    AUTUMN("秋天""3"),
    WINTER("冬天""4");
    
    //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;
    }
    
    //4.其他诉求2:提供toString()
    //如果不重写toString(),默认打印枚举类对象常量SPRING,SUMMER,...
    public String toString(){
        return ----
    }
    
}

Season spring = Season.SPRING;
System.out.println(spring);//SPRING

3 Enum类的主要方法

image-20200821175402454

image-20200821175412397

Season spring = Season.spring;

//values()
Seanson[] values = Season.values();
for(int i = 0; i < values.length; i++){
    System.out.println(values[i]);
    //SPRING
    //SUMMER
    //AUTUMN
    //WINTER
}

//valueOf(String str):根据提供的objName,返回与objName相同名称的枚举类对象。
//如果没有objName的枚举类对象,则抛异常:IlleaglArgumentException
Season winter = Season.valueOf("SPRING");
System.out.println(winter);//WINTER

//toString
System.out.println(spring);//SPRING
System.out.println(spring.toString());//SPRING

4 实现接口的枚举类

image-20200821175425202

每个对象调用show()展现不同的内容

interface Info{
    void show();
}

enum Season implements Info{
    
    //1.提供当前枚举类的对象,多个对象之间用","隔开,末尾对象";"结束
    SPRING("春天""1"){
        @Override
    	public void show(){
        	System.out.println("这是一个春天季节");
   		}
    },
    SUMMER("夏天""2"){
        @Override
    	public void show(){
        	System.out.println("这是一个夏天季节");
   		}
    },
    AUTUMN("秋天""3"){
        @Override
    	public void show(){
        	System.out.println("这是一个秋天季节");
   		}
    },
    WINTER("冬天""4"){
        @Override
    	public void show(){
        	System.out.println("这是一个冬天季节");
   		}
    };
    
    //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;
    }
    
    //4.其他诉求2:提供toString()
    //如果不重写toString(),默认打印枚举类对象常量SPRING,SUMMER,...
    public String toString(){
        return ----
    }
    
    @Override
    public void show(){
        System.out.println("这是一个季节");
    }
    
}

Season spring = Season.SPRING;
Season summer = Season.SUMMER;
spring.show();//这是一个春天季节
summer.show();//这是一个夏天季节
public enum Status{
	FREE,BUSY,VOVATION;
}

二 注解(Annotation)

1 注解(Annotation)概述

image-20200821182645311

image-20200821182653341

2 常见的Annotation示例

2.1 示例一:生成文档相关的注解

image-20200821182707661

package com.annotation.javadoc;
/**
* @author shkstart
* @version 1.0
* @see Math.java
*/
public class JavadocTest {
	
    /**
	* 程序的主方法,程序的入口
	* @param args String[] 命令行参数
	*/
	public static void main(String[] args) {
        
	}
    
    
	/**
	* 求圆面积的方法
	* @param radius double 半径值
	* @return double 圆的面积
	*/
	public static double getArea(double radius){
		return Math.PI * radius * radius;
	}
    
}

2.2 示例二:在编译时进行格式检查(JDK内置的三个基本注解)

image-20200821182731356

package com.annotation.javadoc;
public class AnnotationTest{
	
    public static void main(String[] args) {
		@SuppressWarnings("unused")
		int a = 10;
	}
	
    @Deprecated
	public void print(){
		System.out.println("过时的方法");
	}
	
    @Override
	public String toString() {
		return "重写的toString方法()";
	}
    
}

2.3 示例三:跟踪代码依赖性,实现替代配置文件功能

image-20200821203104683

image-20200821203112991

3 自定义Annotation

image-20200821182757670

如何自定义注解:参照@SuppressWarnings定义

  1. 注解声明为:@interface

  2. 内部定义成员,通常使用value表示

  3. 可以指定成员的默认值,使用default定义

  4. 如果自定义注解没有成员,表明是一个标识作用

    如果自定义注解有成员,在使用注解时,需要指明成员的值

    自定义注解必须配上注解的信息处理流程(使用反射)才有意义。

@MyAnnotation(value = "Hi")
//@MyAnnotation("Hi")
public class MyAnnotationTest {
	public static void main(String[] args) {
		Class clazz = MyAnnotationTest.class;
		Annotation a = clazz.getAnnotation(MyAnnotation.class);
		MyAnnotation m = (MyAnnotation) a;
		String info = m.value();
		System.out.println(info);
	}
}

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.TYPE)
public @interface MyAnnotation{
	String value() default "Hello";
}

4 JDK中的元注解

元注解:对现有注解进行解释说明的注解

image-20200821182816027

4.1 @Retention

image-20200821211005894

image-20200821211116709

SOURCE:javac命令执行后生成的.class文件不会保留被SOURCE修饰的注解的信息

在源文件中有效(即源文件保留),编译器直接丢弃这种策略的 注释

CLASS:会保留到.class文件中,但是不会加载到内存中

在class文件中有效(即class保留) , 当运行 Java 程序时, JVM 不会保留注解。 这是默认值

RUNTIME:会保留到.class文件和加载到内存中,程序可以通过反射获取该注释

在运行时有效(即运行时保留),当运行 Java 程序时, JVM 会 保留注释。程序可以通过反射获取该注释

4.2 @Target

image-20200821211857487

@Target({CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, PARAMETER, TYPE})

4.3 @Documented

表示所修饰的注解在被javadoc解析时,保留下来

image-20200821211951840

4.4 @Inherited

image-20200821211957366

5 利用反射获取注解信息(在反射部分涉及)

image-20200821212547682

public class MyAnnotationTest {
	public static void main(String[] args) {
		Class clazz = MyAnnotationTest.class;
		Annotation a = clazz.getAnnotation(MyAnnotation.class);
		MyAnnotation m = (MyAnnotation) a;
		String info = m.value();
		System.out.println(info);
	}
}

6 JDK 8中注解的新特性

image-20200821213626728

6.1 可重复注解

image-20200821213634676

  1. 在MyAnnotation上声明@Repeatable,成员值为MyAnnotation.class
  2. MyAnnotation的Target和Retention和MyAnnotation相同

6.2 类型注解

image-20200821212609775

image-20200821212618767

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值