Java学习笔记26(枚举和注解)

1.枚举和注解

1.1 枚举

​ 1.枚举(enumeration)

​ 2.枚举是一组常量的集合

​ 3.枚举属于一种特殊的类,里面只包含一组有限的特定的对象

1.枚举应用案例

​ 1.不需要提供setXxx方法,因为枚举对象值通常为只读

​ 2.对枚举对象/属性使用final + static 共同修饰,实现底层优化

​ 3.枚举对象名通常使用全部大写,常量的命名规范

​ 4.枚举对象根据需要,也可以有多个属性

class Season{
    private String name;
    private String description;
    public String getName(){
		return name;
    }
    
    public String getDescription()
    {
		return description;
    }
    
    private Season(String name,String description){
		this.name = name;
        this.description = description;
    }
    
    public final static Seanson SPRING = new Seanson("春天""温暖");
    public final static Seanson SPRING = new Seanson("夏天""炎热");
    public final static Seanson SPRING = new Seanson("秋天""两双");
    public final static Seanson SPRING = new Seanson("冬天""寒冷");
}

​ *进行自定义类型实现枚举的特点

1.构造器私有化

2.本类内部创建一组对象

3.对外暴露对象(public final static)

4.通过get方法

2.enum关键字

enum Seanson2{
	//如果使用了enum来实现枚举类
    //1.使用关键字enum替代class
    //2.public static final Season SPRING = new Season("春天","温暖")直接使用
    //3.常量名(实参列表)
    //4.如果有多个常量(对象),使用逗号间隔即可
    //5.如果使用enum来实现枚举,要求将定义常量对象,写在前面
    SPRING("春天","温暖"),WINTER("冬天",""),AUTUMN("春天","温暖"),SUMMER("春天","温暖");
    private String name;
    private String desc;
    
    private Season(String name,String description){
		this.name = name;
        this.description = description;
    }
}

3.注意事项

​ 1.当使用enum关键字时,会默认隐式继承Enum类,是一个final类型

​ 2.传统的public static final Season SPRING = new Season(“春天”,“温暖”)直接简化为SPRING(“春天”,“温暖”)

​ 3.如果使用无参构造器创建枚举对象,则实参列表和小括号都可以省略,直接SUMMER;

​ 4.当有多个枚举对象时,使用逗号间隔

​ 5.枚举对象必须放在枚举类的首行

4.Enum类成员方法

在这里插入图片描述

​ *valueOf //将字符串转化成枚举对象,要求字符串必须为已有的常量名,否则报异常

​ 1.根据你输入的"AUTUMN"到Season2的枚举对象去查找

​ 2.如果找到了,就返回,如果没找到,就报错

Season2 autumn1 = Season2.valueOf("AUTUMN");
System.out.println("autumn1 =" + autumn1);

​ *toString //得到当前枚举常量的名称

​ *equals //没居中可以直接使用"=="来比较两个枚举常量是否相等

​ *hashCode //

​ *getDeclaringClass //得到枚举常量所属枚举类型的Class对象,用它来判断两个枚举常量是否属于同一个枚举类型

​ *name //得到当前枚举常量的名称,建议优先使用toString()

Season2 autumn = Season2.AUTUMN;
System.out.println(autumn.name());

​ *ordinal //得到当前枚举常量的次序

System.out.println(autumn.ordinal());	//输出autumn在枚举对象的排序位置

​ *compareTo //比较两个枚举常量的大小(按声明的顺序排列),就是比较编号

//1.就是把AUTUMN的编号与Season2.SUMMER的编号进行比较

//2.Season2.AUTUMN的编号 - Season2.SUMMER的编号

System.out.println(Season2.AUTUMN.compareTo(Season2.SUMMER));

​ *clone

​ *values //返回含有定义的所有枚举对象

Season2[] values = Season2.values();
for(Season2 season:values){//增强for循环
	System.out.println(season) 
}

5.使用细节

​ 1.使用enum关键字后,就不能有其它关键字(如extends)了,因为enum关键字会隐式继承Enum类,而Java是单继承机制

​ 2.enum实现的枚举类,仍然是一个类,还是可以实现接口

enum 类名 implements 接口1,接口2{}

1.2 注解

​ *注解(Annotation)也被称为元数据(Metadata),用于修饰解释包、类、方法、属性、构造器、局部变量等数据信息

​ *和注释一样,注解不影响程序逻辑,但注解可以被编译或运行,相当于嵌入在代码中的补充信息

1.基本介绍

​ *使用Annotation时要在其前面增加@符号,并把该Annotation当成一个修饰符使用,用于修饰它支持的程序元素

​ *三个基本的Annotation

1.@Override:限定某个方法,是表示重写父类的方法,该注解只能用于方法

2.@Deprecated:用于表示某个程序元素(类,方法等)已过时

3.@SuppressWarnings:抑制编译器警告

2.@Override说明

​ 1.@Override表示制定重写父类的方法,如果父类没有此方法,则会报错

​ 2.不过不写@Override注解,而父类仍有此方法,仍然构成重写

​ 3.@Override只能修饰方法,不能修饰其它类,包,属性等等

​ 4.@Target是修饰注解的注解,称为元注解

  • 16
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值