第十章_枚举类&注解-Day21-《Java学习知识库》

admin 2025-11-02 01:03:02 编程 来源:ZONE.CI 全球网 0 阅读模式
  • 1、昨日复习
  • 2、枚举类
  • 3、注解(Annotation)

    1、昨日复习

    1. 将字符串”2017-08-16”转换为对应的java.sql.Date类的对象。(使用JDK8之前或JDK8中的API皆可)SimpleDateFormat sdf = new SimpleDateFormat(“yyyy-MM-dd”);解析:java.util.Date date = sdf.parse(“2017-08-16”);

    DateTimeFormatter dtf= DateTimeFormatter.ofPattern(“yyyy-MM-dd”);

    new + 构造器单例、Calendar.getInstance()

    1. 解释何为编码?解码?何为日期时间的格式化?解析?编码:字符串à字节解码:字节à字符串

    格式化:日期à字符串解析:字符串à日期3. 自定义Person类如下,如何实现自然排序(按姓名从小到大排序),代码说明class Person implements Comparable{private String name;private int age;public int compareTo(Object obj){//… this.name.compareTo(s.name);}}4. 提供定制排序涉及到的接口的实现类对象,并按Person类的年龄从大到小排序Comparator com = new Comparator(){public int compare(Object obj1,Object obj2){if(){}}};5. JDK 8之前和JDK8中日期、时间相关的类分别有哪些?java.util.Date 和 java.sql.Date —-> InstantSimpleDateFormat —-> DateTimeFormatterCalendar —-> LocalDate、LocalTime、LocalDateTime

    2、枚举类

    1. package com.atguigu.java1;
    2. /**
    3. * 一、枚举类的使用
    4. * 1、枚举类的理解:类的对象只有有限个,确定的。我们称此类为枚举类。
    5. * 2、当需要定义一组常量时,强烈建议使用枚举类
    6. * 3、如果枚举类中只有一个对象,则可以作为单列模式的实现方式。
    7. *
    8. * 二、如何定义枚举类
    9. * 方式一:jdk5.0之前,自定义枚举类
    10. * 方式二:jdk5.0之后,可以使用enum关键字定义枚举类
    11. *
    12. * 三、enum类中的常用方法
    13. *  values()方法:返回枚举类型的对象数组。该方法可以很方便地遍历所有的
    14. * 枚举值。
    15. *  valueOf(String str):可以把一个字符串转为对应的枚举类对象。要求字符
    16. * 串必须是枚举类对象的“名字”。如不是,会有运行时异常:IllegalArgumentException。
    17. *  toString():返回当前枚举类对象常量的名称
    18. *
    19. * 四、使用enum关键字定义的枚举类实现接口的情况
    20. * 情况一:实现接口,在enum类中实现抽象方法
    21. * 情况二:让枚举类的对象分别实现接口中的抽象方法
    22. */
    23. public class SeasonTest {
    24. public static void main(String[] args) {
    25. Season spring = Season.SPRING;
    26. System.out.println(spring);
    27. System.out.println(spring.getSeasonName());
    28. }
    29. }
    30. class Season {
    31. //1、声明Season对象的属性:private final修饰
    32. private final String seasonName;
    33. private final String seasonDesc;
    34. //2、私有化类的构造器,并给对象属性赋值
    35. private Season(String seasonName, String seasonDesc) {
    36. this.seasonName = seasonName;
    37. this.seasonDesc = seasonDesc;
    38. }
    39. //3、提供当前枚举类的多个对象:public static final的
    40. public static final Season SPRING = new Season("春天", "春暖花开");
    41. public static final Season SUMMER = new Season("夏天", "夏日炎炎");
    42. public static final Season AUTUMN = new Season("秋天", "秋高气爽");
    43. public static final Season WINTER = new Season("冬天", "冰天雪地");
    44. //4、其他诉求1:获取枚举类对象的属性
    45. public String getSeasonName() {
    46. return seasonName;
    47. }
    48. public String getSeasonDesc() {
    49. return seasonDesc;
    50. }
    51. //4、其他诉求2:提供toString()方法
    52. @Override
    53. public String toString() {
    54. return "Season{" +
    55. "seasonName='" + seasonName + '\'' +
    56. ", seasonDesc='" + seasonDesc + '\'' +
    57. '}';
    58. }
    59. }
    1. package com.atguigu.java1;
    2. public class SeasonTest1 {
    3. public static void main(String[] args) {
    4. Season1 summer = Season1.SUMMER;
    5. System.out.println(summer);//Season{seasonName='夏天', seasonDesc='夏日炎炎'}如果不重写toString()方法则输出SUMMER即对象名
    6. System.out.println("****************************************");
    7. //values()
    8. Season1[] values = Season1.values();
    9. for (int i = 0; i < values.length; i++) {
    10. System.out.println(values[i]);
    11. values[i].show();
    12. }
    13. System.out.println("****************************************");
    14. Thread.State[] values1 = Thread.State.values();
    15. for (int i = 0; i < values1.length; i++) {
    16. System.out.println(values1[i]);
    17. }
    18. System.out.println("****************************************");
    19. //valueOf(String str)返回枚举类中对象名是str的对象,如果没有str的枚举类对象,则抛异常:IllegalArgumentException
    20. Season1 winter = Season1.valueOf("WINTER");
    21. System.out.println(winter);
    22. winter.show();
    23. }
    24. }
    25. interface info{
    26. void show();
    27. }
    28. //使用enum关键字枚举类
    29. enum Season1 implements info {
    30. //1、提供当前枚举类的多个对象,多个对象之间用“,”隔开,末尾对象“;”结束
    31. SPRING("春天", "春暖花开"){
    32. @Override
    33. public void show() {
    34. System.out.println("春天在哪里");
    35. }
    36. },
    37. SUMMER("夏天", "夏日炎炎"){
    38. @Override
    39. public void show() {
    40. System.out.println("夏天在哪里");
    41. }
    42. },
    43. AUTUMN("秋天", "秋高气爽"){
    44. @Override
    45. public void show() {
    46. System.out.println("秋天不回来");
    47. }
    48. },
    49. WINTER("冬天", "冰天雪地"){
    50. @Override
    51. public void show() {
    52. System.out.println("冬天不远了");
    53. }
    54. };
    55. //2、声明Season对象的属性:private final修饰
    56. private final String seasonName;
    57. private final String seasonDesc;
    58. //3、私有化类的构造器,并给对象属性赋值
    59. private Season1(String seasonName, String seasonDesc) {
    60. this.seasonName = seasonName;
    61. this.seasonDesc = seasonDesc;
    62. }
    63. //4、其他诉求1:获取枚举类对象的属性
    64. public String getSeasonName() {
    65. return seasonName;
    66. }
    67. public String getSeasonDesc() {
    68. return seasonDesc;
    69. }
    70. //4、其他诉求2:提供toString()方法
    71. /*
    72. @Override
    73. public String toString() {
    74. return "Season{" +
    75. "seasonName='" + seasonName + '\'' +
    76. ", seasonDesc='" + seasonDesc + '\'' +
    77. '}';
    78. }*/
    79. /* @Override
    80. public void show() {
    81. System.out.println("这是一个季节");
    82. }*/
    83. }

    3、注解(Annotation)

    QQ截图20220117173135.pngQQ截图20220419125813.png

    1. package com.atguigu.java2;
    2. /**
    3. * 注解的使用
    4. * 1、理解Annotation
    5. * ①jdk5.0新增的
    6. * <p>
    7. * ②Annotation 其实就是代码里的特殊标记, 这些标记可以在编译, 类加
    8. * 载, 运行时被读取, 并执行相应的处理。通过使用 Annotation, 程序员
    9. * 可以在不改变原有逻辑的情况下, 在源文件中嵌入一些补充信息。
    10. * <p>
    11. * ③在JavaSE中,注解的使用目的比较简单,例如标记过时的功能,
    12. * 忽略警告等。在JavaEE/Android中注解占据了更重要的角色,例如
    13. * 用来配置应用程序的任何切面,代替JavaEE旧版中所遗留的繁冗
    14. * 代码和XML配置等。
    15. * <p>
    16. * 2、Annotation的使用实例
    17. * 实例一:生成文档相关的注解
    18. * 实例二:在编译时进行格式检查(JDK内置的三个基本注解)
    19. *
    20. * @Override: 限定重写父类方法, 该注解只能用于方法
    21. * @Deprecated: 用于表示所修饰的元素(类, 方法等)已过时。通常是因为所修饰的结构危险或存在更好的选择
    22. * @SuppressWarnings: 抑制编译器警告
    23. * 实例三:跟踪代码依赖性,实现替代配置文件功能
    24. * <p>
    25. * 3、如何自定义注解:参照@SuppressWarnings定义
    26. * ①注解声明为:@interface
    27. * ②内部定义成员,通常使用value表示
    28. * ③可以指定成员的默认值,使用default定义
    29. * ④如果自定义注解没有成员,表明是一个标识作用
    30. * <p>
    31. * 如果注解有成员,在使用注解时,需要指明成员的值
    32. * 自定义注解必须配上注解的信息处理流程才有意义。
    33. * 自定义注解通常都会指明两个元注解:Retention、Target
    34. * 4、jdk提供的5种元注解
    35. * 元注解:对现有的注解进行解释说明的注解
    36. * Retention:指定所修饰的Annotation 的生命周期:SOURCE、CLASS(默认行为)、RUNTIME;
    37. * 只有声明为RUNTIME生命周期的注解才能通过反射获取
    38. * Target:用于指定被修饰的 Annotation 能用于修饰哪些程序元素。
    39. * Documented:表示所修饰的注解在被该javadoc解析时,保留下来
    40. * Inherited:被它修饰的 Annotation 将具有继承性。如果某个类使用了被@Inherited 修饰的 Annotation, 则其子类将自动具有该注解。
    41. * Repeatable:Repeatable 自然是可重复的意思。@Repeatable 是 Java 1.8 才加进来的,所以算是一个新的特性。
    42. * 5、通过反射获取注解信息----到反射内容时系统讲解
    43. *
    44. * 6、jdk8中注解的新特性:可重复注解、类型注解
    45. * 6.1 可重复注解:①在@MyAnnotation上声明@Repeatable,成员值为MyAnnotations.class
    46. * ②MyAnnotation的Target和Retention等元注解与MyAnnotations相同
    47. * 6.2 类型注解:
    48. *  ElementType.TYPE_PARAMETER 表示该注解能写在类型变量的声明语句中(如:泛型声明)。
    49. *  ElementType.TYPE_USE 表示该注解能写在使用类型的任何语句中。
    50. *
    51. *
    52. */
    53. public class AnnotationTest {
    54. }
    55. @MyAnnotation(value = "hello")
    56. class Person {
    57. private String name;
    58. private int age;
    59. public Person() {
    60. }
    61. public Person(String name, int age) {
    62. this.name = name;
    63. this.age = age;
    64. }
    65. public void walk() {
    66. System.out.println("人走路");
    67. }
    68. public void eat() {
    69. System.out.println("人吃饭");
    70. }
    71. }
    72. interface Info {
    73. void show();
    74. }
    75. class Student extends Person implements Info {
    76. @Override
    77. public void walk() {
    78. System.out.println("学生走路");
    79. }
    80. @Override
    81. public void show() {
    82. }
    83. }

    @Retention: 只能用于修饰一个 Annotation 定义, 用于指定该 Annotation 的生命周期, @Rentention 包含一个 RetentionPolicy 类型的成员变量, 使用 @Rentention 时必须为该 value 成员变量指定值: RetentionPolicy.SOURCE:在源文件中有效(即源文件保留),编译器直接丢弃这种策略的注释 RetentionPolicy.CLASS:在class文件中有效(即class保留) , 当运行 Java 程序时, JVM不会保留注解。 这是默认值 RetentionPolicy.RUNTIME:在运行时有效(即运行时保留),当运行 Java 程序时, JVM 会保留注释。程序可以通过反射获取该注释。QQ截图20220118130216.pngQQ截图20220404204408.png


    @Repeatable是jdk8中新增的注解,使用如Spring中的@ComponentScan注解。在没有@Repeatable注解的的注解中,在同一个地方使用相同的注解会报错,有了此元注解注解的注解,就可以在同一个地方使用相同的注解。其官方文档如下

    The annotation type {@code java.lang.annotation.Repeatable} is used to indicate that the annotation type whose declaration it (meta-)annotates is repeatable. The value of @Repeatable indicates the containing annotation type for the repeatable annotation type.@Repeatable 注解是用于声明其它类型注解的元注解,来表示这个声明的注解是可重复的。@Repeatable的值是另一个注解,其可以通过这个另一个注解的值来包含这个可重复的注解。

    1. @Target(ElementType.METHOD)
    2. @Retention(RetentionPolicy.RUNTIME)
    3. @Repeatable(Values.class)
    4. public @interface Value {
    5. String value() default "value";
    6. }
    1. @Target(ElementType.METHOD)
    2. @Retention(RetentionPolicy.RUNTIME)
    3. public @interface Values {
    4. Value[] value();
    5. }

    其中,@Value注解上的元注解@Repeatable中的值,使用了@Values注解,@Values注解中包含的值类型是一个@Value注解的数组!这就解释了官方文档中@Repeatable中值的使用。————————————————版权声明:本文为CSDN博主「看山也看水」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。原文链接:https://blog.csdn.net/weixin_42245133/article/details/99678509

    尚硅谷宋红康第10章_枚举类与注解.pdf

    以太坊cppgolang区别 编程

    以太坊cppgolang区别

    以太坊是一种去中心化的开源平台,它采用智能合约技术,旨在构建和运行不受干扰的分布式应用程序。作为目前最受欢迎的区块链平台之一,以太坊提供了多种编程语言的支持,其
    progolang 编程

    progolang

    Go语言(Golang)是由Google开发的一门静态类型编程语言。作为一名专业的Golang开发者,我深知这门语言的优势和特点。在本文中,我将介绍Golang
    golangn个发送者 编程

    golangn个发送者

    Golang是一种开源的编程语言,由Google团队开发,旨在提高程序的并发性和简化软件开发过程。在Go语言中,有时需要向多个接收者发送信息。本文将介绍如何在G
    golang技能图谱 编程

    golang技能图谱

    从互联网行业的快速发展到人工智能技术的日益成熟,各种编程语言也应运而生。而在这众多的编程语言中,Golang(即Go)作为一门强大且高效的开发语言备受关注。Go
    评论:0   参与:  5