枚举类与注解(1天)

文章要点

枚举:
		使用enum关键字定义枚举类
		Enum类的主要方法(3个)

注解:

枚举类

自定义枚举类(JDK 5.0之前)
视频498 		枚举类的理解
1、类的对象只有有限个,确定的。我们称此类为枚举类。
星期:Monday(星期一)......、Sunday(星期天)

2、当需要定义一组常量(不可修改)时,强烈建议使用枚举类。

视频499		自定义枚举类
自定义枚举类

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:获取枚举类对象的属性(只能生成get()方法了)
    public String getSeasonName() {
        return seasonName;
    }

    public String getSeasonDesc() {
        return seasonDesc;
    }
    //4.其他诉求1:提供toString()
    @Override
    public String toString() {
        return "Season{" +
                "seasonName='" + seasonName + '\'' +
                ", seasonDesc='" + seasonDesc + '\'' +
                '}';
    }
}
使用关键字enum定义枚举类(JDK 5.0)(以后常用)(重点)
视频500		使用关键字enum定义枚举类
public class Test999 {
    public static void main(String[] args) {
        Senson2 spring = Senson2.SPRING1;

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

        //如果不重写toString方法,那么返回枚举类对象的名称  SPRING1
        //如果重写toString方法,那么输出   Senson2{sensonName2='春天', sensonDesc2='春暖花开'}
        System.out.println(spring);

        //class java.lang.Enum(获取到的父类)
        System.out.println(Senson2.class.getSuperclass());

    }
}

enum Senson2 {
    //提供当前枚举类的对象,必须放在最开始的地方。多个对象之间用逗号,分割,最后一个对象后面用分号;结尾
    SPRING1("春天", "春暖花开"),
    SUMMER1("夏天", "夏日炎炎"),
    AUTUMN1("秋天", "秋高气爽"),
    WINTER1("冬天", "冰天雪地");

    //声明Season2对象的属性:private final修饰
    private final String sensonName2;
    private final String sensonDesc2;

    //私有化类的构造器,并给对象的属性赋值
    Senson2(String sensonName2, String sensonDesc2) {
        this.sensonName2 = sensonName2;
        this.sensonDesc2 = sensonDesc2;
    }
    //重写toString()方法,否则继承java.lang.Enum类中的
    @Override
    public String toString() {
        return "Senson2{" +
                "sensonName2='" + sensonName2 + '\'' +
                ", sensonDesc2='" + sensonDesc2 + '\'' +
                '}';
    }
}
Enum类的主要方法(3个)(重点)
实现接口的枚举类
视频501		Enum类的3个主要方法	

		values()方法:返回枚举类型的对象数组。该方法可以很方便地遍历所有的枚举值。
		valueOf(String str):可以把一个字符串转为对应的枚举类对象。要求字符串必须是枚举类对象的“名字”。
				如不是,会有运行时异常:IllegalArgumentException。
		toString():返回当前枚举类对象常量的名称
视频502 		使用enum关键字定义的枚举类实现接口
		情况一:实现接口,在enum类中实现抽象方法
		情况二:让枚举类的对象分别实现接口中的抽象方法
public class Test999 {
    public static void main(String[] args) {
        Senson2 spring = Senson2.SPRING1;

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

        //如果不重写toString方法,那么返回枚举类对象的名称  SPRING1
        //如果重写toString方法,那么输出   Senson2{sensonName2='春天', sensonDesc2='春暖花开'}

        //方法1:toString():返回当前枚举类对象常量的名称
        System.out.println(spring.toString());

        //class java.lang.Enum(获取到的父类)
        System.out.println(Senson2.class.getSuperclass());

        //方法2:values():返回枚举类型的对象数组。该方法可以很方便地遍历所有的枚举值
        Senson2[] values = Senson2.values();
        System.out.println("values()========================================");
        for (int i = 0; i < values.length; i++) {
            System.out.println(values[i]);
            values[i].show();
        }
        //输出结果:
                //SPRING1
                //SUMMER1
                //AUTUMN1
                //WINTER1

        //valueOf(String objName):返回枚举类中对象名是objName的对象。
        Senson2 winter1 = Senson2.valueOf("WINTER1");
        System.out.println(winter1);
        //如果没有objName的枚举类对象,则抛异常:IllegalArgumentException。如下:
//        Senson2 winter2 = Senson2.valueOf("WINTER11");


    }
}

interface Info1{
    void show();
}

enum Senson2 implements Info1{
    //提供当前枚举类的对象,必须放在最开始的地方。多个对象之间用逗号,分割,最后一个对象后面用分号;结尾
    SPRING1("春天", "春暖花开"){
        @Override
        public void show() {
            System.out.println("chun");
        }
    },
    SUMMER1("夏天", "夏日炎炎"){
        @Override
        public void show() {
            System.out.println("xia");
        }
    },
    AUTUMN1("秋天", "秋高气爽"){
        @Override
        public void show() {
            System.out.println("qiu");
        }
    },
    WINTER1("冬天", "冰天雪地"){
        @Override
        public void show() {
            System.out.println("dong");
        }
    };

    //声明Season2对象的属性:private final修饰
    private final String sensonName2;
    private final String sensonDesc2;

    //私有化类的构造器,并给对象的属性赋值
    Senson2(String sensonName2, String sensonDesc2) {
        this.sensonName2 = sensonName2;
        this.sensonDesc2 = sensonDesc2;
    }

    //情况一:实现接口,在enum类中实现抽象方法
    //但是,我们希望:
    //情况二:让枚举类的对象分别实现接口中的抽象方法。所以,我们让每一个对象重写一下show()方法,如上重写的4个show()
    /*@Override
    public void show() {
        System.out.println("实现了接口中的抽象方法");
    }*/
    //重写toString()方法,否则继承java.lang.Enum类中的
   /* @Override
    public String toString() {
        return "Senson2{" +
                "sensonName2='" + sensonName2 + '\'' +
                ", sensonDesc2='" + sensonDesc2 + '\'' +
                '}';
    }*/
}

注解(Annotation)(框架中非常重要)

未来的开发模式都是基于注解的,JPA是基于注解的,Spring2.5以上都是基于注解的,Hibernate3.x以后也是基于注解的,现在的
Struts2有一部分也是基于注解的了,注解是一种趋势,一定程度上可以说:框架 = 注解 + 反射 + 设计模式。
注解概述(视频504)
1. 理解Annotation:
2. 
jdk 5.0 新增的功能
Annotation 其实就是代码里的特殊标记, 这些标记可以在编译, 类加载, 运行时被读取, 并执行相应的处理。通过使用 Annotation,
程序员可以在不改变原有逻辑的情况下, 在源文件中嵌入一些补充信息
在JavaSE中,注解的使用目的比较简单,例如标记过时的功能,忽略警告等。在JavaEE/Android中注解占据了更重要的角色,例如用来
配置应用程序的任何切面,代替JavaEE旧版中所遗留的繁冗代码和XML配置等。
常见的Annotation示例(视频505、506)
2. Annocation的使用示例

示例一:生成文档相关的注解
示例二:在编译时进行格式检查(JDK内置的三个基本注解)			(视频506@Override: 限定重写父类方法, 该注解只能用于方法
     @Deprecated: 用于表示所修饰的元素(, 方法等)已过时。通常是因为所修饰的结构危险或存在更好的选择
     @SuppressWarnings: 抑制编译器警告

示例三:跟踪代码依赖性,实现替代配置文件功能
编译时检查
@Override
public void walk() {
    System.out.println("学生走路");
}

过时,不推荐使用;或者有更好的选择
@Deprecated

提示未使用
@SuppressWarnings("unused")
int num = 10;
自定义Annotation(视频507)

使用较少,后续更多的是使用框架中所提供的的现成的,直接使用即可。

在这里插入代码片
JDK中的元注解(视频508、509)
利用反射获取注解信息(在反射部分涉及)
JDK 8中注解的新特性(视频510、511)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Lacrimosa&L

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值