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;
}
}
========================================================================================
-
情况一:实现接口,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(“春夏秋冬”);
}
}
===============================================================================
像@Test,@Override等都是注解,在代码里注解就是特殊标记。
生成文档相关的注解:
JDK内置的三个基本注解:
注解功能之一:可以实现替代配置文件功能:
@BeforeClass,@AfterClass等等以下注解很常用!!要记住!
=========================================================================
-
注解是从JDK5.0开始的,Java增加了对元数据(MetaData)的支持,也就是Annotation(注解)。
-
他到后面最主要的功能就是代替旧版中所遗留的繁冗代码和XML配置等操作。
============================================================================
@Override注解:重写标志,如果报错或者没有变颜色说明代码有问题!
@Deprecated注解:代表已经过时了,但是还可以用!deprecated英文意思是贬低,强烈反对的意思。
通常是因为所修饰的结构危险或存在更好的选择。
@SuppressWarning抑制编译器警告注解,这个很有意思,它就是用来抑制编译器警告的,说的通俗一点就是用来去除警告的。
@SuppressWarning(“xxx”,“xxx”)它可以携带很多参数,每个参数都有不同作用,例如:"unuse"代表未使用,"rawtypes"代表传参时也要传递带泛型的参数等等。
在eclipse中,我们没有用到的变量属性什么的,它会报黄色线条的警告。
在IDEA中,他没有黄色警告,但是它是淡黑的,告诉你没有用到该变量。
同样,我们添加抑制编译器注解后,他就变成正常颜色了。
======================================================================
创建时,要选择Annotation注解类型:
注解的声明就是@interface:
注意:注解和interface接口没有任何关系,@interface就是这么个结构。
自定义注解自动继承了java.lang.annotation.Annotation接口。
内部定义成员,通常使用value表示:
参数名 = “参数值” 形式:
可以指定成员的默认值,使用default定义:
如果自定义注解没有成员,表明是一个标识作用。
就像标识接口差不多,都是标识作用:
当然,相反如果注解有成员,在使用注解时,需要指定成员的值。
自定义注解必须配上注解的信息处理流程(使用反射)才有意义。
==========================================================================
- **JDK的元Annotation(注解)用于修饰其他Annotation(注解)定义的。
简而言之,就是修饰其他注解的注解叫元注解。**
同样还有一个叫做元数据:
- JDK提供的4中元注解:
@Retention元注解:指定所修饰的Annotation的生命周期:SOURCE、CLASS(默认)、RUNTIME(只有声明为RUNTIME生命周期的注解,才能通过反射获取。)
source:注解只保留在源文件,当Java文件编译成class文件的时候,注解被遗弃;被编译器忽略
class:注解被保留到class文件,但jvm加载class文件时候被遗弃,这是默认的生命周期
runtime:注解不仅被保存到class文件中,jvm加载class文件之后,仍然存在
RetentionPolicy的默认值是CLASS,编译时有,运行时不加载。
其中,RetentionPolicy就是一个枚举类,包含三种状态:
我们常用的SuppressWarnings就是使用的Retention注解:
@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”;
}
@Documented元注解:表示所修饰得注解在被javadoc解析(生成文档)时,保留下来。
@Inherited元注解:被它修饰的注解,将具有继承性,其子类就会继承父类的注解。
如果想要打印注解信息到一个数组中可以像下面这么做:
================================================================================
Annotation注解数组方式重复注解(过时,JDK 8之前的写法):
package com.holmes.java06;
public @interface MyAnnotations {
//首先,定义一个注解数组,在这里面。
MyAnnotation[] value();
}
我们使用@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开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
eld:属性;method:方法;parameter:形参;constructor:构造器;local_variable:局部变量
public @interface MyAnnotation {
String value() default “hello”;
}
具体步骤如下:
- 第一步:在MyAnnotation上声明@Repeatable , 成员值为MyAnnotations.class。
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-HXtAITqR-1714801259791)]
[外链图片转存中…(img-Z4Ogim73-1714801259792)]
[外链图片转存中…(img-h9cupPnf-1714801259793)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!