Java 基础知识点 笔记总结 (八)(1)

package com.holmes.java06;

public class SeasonTest {

public static void main(String[] args) {

Season summer = Season.SUMMER;

//1.toString()方法:

System.out.println(summer.toString());

System.out.println(“***************”);

//2.values()方法:

Season[] values = Season.values();

for (int i=0; i < values.length;i++){

System.out.println(values[i]);

}

System.out.println(“********”);

//同样在之前的Thread.State状态也是enum定义的:

Thread.State[] values1 = Thread.State.values();

for (int i=0; i < values1.length;i++){

System.out.println(values1[i]);

}

System.out.println(“***************”);

//3.valueOf(String objName)方法:返回枚举类中对象名是objName的对象

Season winter = Season.valueOf(“WINTER”);

System.out.println(winter);//默认调用toString()方法,还是返回对象名。

//如果没找到,就会报错IllegalArgumentException。

}

}

//方式二:使用enum关键字枚举类

enum Season{

//1.提供当前枚举类的对象,多个对象之间用",“隔开,末尾对象用”;"结束。

SPRING(“春天”,“春暖花开”),

SUMMER(“夏天”,“夏日炎炎”),

AUTUMN(“秋天”,“秋高气爽”),

WINTER(“冬天”,“冰天雪地”);

//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;

}

}

5. 使用enum关键字定义的枚举类 实现接口的情况

========================================================================================

  • 情况一:实现接口,enum枚举类实现接口并实现其抽象方法。

  • 情况二:每个对象可以给自己单独设置重写方法,如下:

package com.holmes.java06;

public class SeasonTest {

public static void main(String[] args) {

Season summer = Season.SUMMER;

//调用自己单独重写的方法

summer.show();

Season winter = Season.WINTER;

//自己没有定义那就调用共用的重写的方法

winter.show();

}

}

interface Info{

void show();

}

//方式二:使用enum关键字枚举类

enum Season implements Info{

SPRING(“春天”,“春暖花开”){

@Override

public void show() {

System.out.println(“这是一个春天”);

}

},

SUMMER(“夏天”,“夏日炎炎”){

@Override

public void show() {

System.out.println(“这是一个夏天”);

}

},

AUTUMN(“秋天”,“秋高气爽”){

@Override

public void show() {

System.out.println(“这是一个春天秋天”);

}

},

WINTER(“冬天”,“冰天雪地”);

private final String seasonName;

private final String seasonDesc;

private Season(String seasonName,String seasonDesc){

this.seasonName = seasonName;

this.seasonDesc = seasonDesc;

}

public String getSeasonName() {

return seasonName;

}

public String getSeasonDesc() {

return seasonDesc;

}

@Override

public void show() {

//在这的方法代表所有对象默认调用该方法,每个对象也可以自己重写自己的方法。

System.out.println(“春夏秋冬”);

}

}

6. 注解(Annotation)

===============================================================================


像@Test,@Override等都是注解,在代码里注解就是特殊标记。

在这里插入图片描述


生成文档相关的注解:

在这里插入图片描述


JDK内置的三个基本注解:

在这里插入图片描述


注解功能之一:可以实现替代配置文件功能:

在这里插入图片描述


@BeforeClass,@AfterClass等等以下注解很常用!!要记住!

在这里插入图片描述

7. 注解 起源 功能

=========================================================================

  • 注解是从JDK5.0开始的,Java增加了对元数据(MetaData)的支持,也就是Annotation(注解)。

  • 他到后面最主要的功能就是代替旧版中所遗留的繁冗代码和XML配置等操作。

8. 三个JDK内置基本注解

============================================================================

8.1 @Override注解



@Override注解:重写标志,如果报错或者没有变颜色说明代码有问题!

8.2 @Deprecated注解



@Deprecated注解:代表已经过时了,但是还可以用!deprecated英文意思是贬低,强烈反对的意思。

通常是因为所修饰的结构危险或存在更好的选择。

8.3 @SuppressWarning注解



@SuppressWarning抑制编译器警告注解,这个很有意思,它就是用来抑制编译器警告的,说的通俗一点就是用来去除警告的。

@SuppressWarning(“xxx”,“xxx”)它可以携带很多参数,每个参数都有不同作用,例如:"unuse"代表未使用,"rawtypes"代表传参时也要传递带泛型的参数等等。


在eclipse中,我们没有用到的变量属性什么的,它会报黄色线条的警告。

在这里插入图片描述

在这里插入图片描述


在IDEA中,他没有黄色警告,但是它是淡黑的,告诉你没有用到该变量。

在这里插入图片描述

同样,我们添加抑制编译器注解后,他就变成正常颜色了。

在这里插入图片描述

9. 自定义注解

======================================================================


创建时,要选择Annotation注解类型:

在这里插入图片描述

在这里插入图片描述


注解的声明就是@interface:

注意:注解和interface接口没有任何关系,@interface就是这么个结构。

自定义注解自动继承了java.lang.annotation.Annotation接口。

在这里插入图片描述


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

在这里插入图片描述


参数名 = “参数值” 形式:

在这里插入图片描述


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

在这里插入图片描述


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

就像标识接口差不多,都是标识作用:

在这里插入图片描述

当然,相反如果注解有成员,在使用注解时,需要指定成员的值。

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

10. JDK中的元注解

==========================================================================

10.1 什么是元注解?



  • **JDK的元Annotation(注解)用于修饰其他Annotation(注解)定义的。

简而言之,就是修饰其他注解的注解叫元注解。**

同样还有一个叫做元数据:

在这里插入图片描述

  • JDK提供的4中元注解:

在这里插入图片描述

10.2 @Retention 元注解



@Retention元注解:指定所修饰的Annotation的生命周期:SOURCE、CLASS(默认)、RUNTIME(只有声明为RUNTIME生命周期的注解,才能通过反射获取。)

source:注解只保留在源文件,当Java文件编译成class文件的时候,注解被遗弃;被编译器忽略

class:注解被保留到class文件,但jvm加载class文件时候被遗弃,这是默认的生命周期

runtime:注解不仅被保存到class文件中,jvm加载class文件之后,仍然存在


RetentionPolicy的默认值是CLASS,编译时有,运行时不加载。

在这里插入图片描述

其中,RetentionPolicy就是一个枚举类,包含三种状态:

在这里插入图片描述

我们常用的SuppressWarnings就是使用的Retention注解:

在这里插入图片描述

10.3 @Target 元注解


@Target元注解:用于指明我们所修饰的注解,它能修饰哪些程序元素。

package com.holmes.java06;

import java.lang.annotation.Target;

import static java.lang.annotation.ElementType.*;

import static java.lang.annotation.ElementType.LOCAL_VARIABLE;

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

//上面参数代表不同可以修饰不同的类型效果:

//type:类,接口,枚举类;field:属性;method:方法;parameter:形参;constructor:构造器;local_variable:局部变量

public @interface MyAnnotation {

String value() default “hello”;

}

10.4 @Documented 元注解


@Documented元注解:表示所修饰得注解在被javadoc解析(生成文档)时,保留下来。

在这里插入图片描述

10.5 @Inherited 元注解


@Inherited元注解:被它修饰的注解,将具有继承性,其子类就会继承父类的注解。

在这里插入图片描述

如果想要打印注解信息到一个数组中可以像下面这么做:

在这里插入图片描述

11. JDK8 新特性 可重复注解

================================================================================

11.1 JDK 1.8 版本之前



Annotation注解数组方式重复注解(过时,JDK 8之前的写法):

package com.holmes.java06;

public @interface MyAnnotations {

//首先,定义一个注解数组,在这里面。

MyAnnotation[] value();

}

在这里插入图片描述

11.2 JDK 1.8 版本之后


我们使用@Repeatable注解来解决:

MyAnnotations注解内容:

package com.holmes.java06;

import java.lang.annotation.Retention;

import java.lang.annotation.RetentionPolicy;

import java.lang.annotation.Target;

import static java.lang.annotation.ElementType.*;

import static java.lang.annotation.ElementType.LOCAL_VARIABLE;

@Retention(RetentionPolicy.RUNTIME)

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

public @interface MyAnnotations {

//首先,定义一个注解数组,在这里面。

MyAnnotation[] value();

}

MyAnnotation注解内容:

package com.holmes.java06;

import java.lang.annotation.*;

import static java.lang.annotation.ElementType.*;

import static java.lang.annotation.ElementType.LOCAL_VARIABLE;

@Inherited

@Repeatable(MyAnnotations.class)

@Retention(RetentionPolicy.RUNTIME)

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

//上面参数代表不同可以修饰不同的类型效果:

//type:类,接口,枚举类;field:属性;method:方法;parameter:形参;constructor:构造器;local_variable:局部变量

public @interface MyAnnotation {

String value() default “hello”;

}

具体步骤如下:

  • 第一步:在MyAnnotation上声明@Repeatable , 成员值为MyAnnotations.class。

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
;field:属性;method:方法;parameter:形参;constructor:构造器;local_variable:局部变量

public @interface MyAnnotation {

String value() default “hello”;

}

具体步骤如下:

  • 第一步:在MyAnnotation上声明@Repeatable , 成员值为MyAnnotations.class。

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

[外链图片转存中…(img-TlbOxDax-1715704465505)]

[外链图片转存中…(img-KxnJbLvb-1715704465506)]

[外链图片转存中…(img-5uKSs0yO-1715704465506)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值