0基础Java学习过程记录——枚举、注解

一、枚举

1.基本介绍

(1)枚举对应英文 enumeration,简写为 enum

(2)枚举是一组常量的集合

(3)可以理解为:枚举属于一种特殊的类,里面只包含一组有限的特定的对象

2.实现方式

(1)自定义类实现枚举

1)步骤

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

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

3.枚举对象名通常使用全部大写,遵循敞亮的命名规范

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

package com.figiting.enum_;/*** @version 1.0* @autor 疯小丢*/
public class Enumeration01 {public static void main(String[] args) {System.out.println(Season.SPRING);System.out.println(Season.SUMMER);System.out.println(Season.AUTUMN);System.out.println(Season.WINNER);}
}class Season{private String name;private String desc;//定义了四个对象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 WINNER = new Season("冬天","寒冷");//1.构造器私有化,防止直接new//3.在Season内部,直接创建固定对象//4.优化,可以加入final修饰符private Season(String name, String desc) {this.name = name;this.desc = desc;}public String getName() {return name;}//2.去掉set相关方法,只读不修改,防止属性被修改/*public void setName(String name) {this.name = name;}*/public String getDesc() {return desc;}@Overridepublic String toString() {return "Season{" +"name='" + name + '\'' +", desc='" + desc + '\'' +'}';}/*public void setDesc(String desc) {this.desc = desc;}*/
}
2)特点

1.构造器私有化

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

3.对外暴露对象(通过为对象添加public final static修饰符)

4.可以提供get方法,但是不要提供set

(2)使用enum关键字

package com.figiting.enum_;/*** @version 1.0* @autor 疯小丢*/
public class Enumeration02 {public static void main(String[] args) {//使用Season2枚举类演示方法Season2 autumn = Season2.AUTUMN;//输出枚举对象的名称System.out.println(autumn.name());//输出该枚举对象的次序/编号,从0开始编号System.out.println(autumn.ordinal());//values()返回枚举对象,Season[]Season2[] values = Season2.values();for(Season2 season : values){//增强for循环//依次从数组中取出System.out.println(season);}//valueOf():将字符串转换成枚举对象,要求字符串必须为已有的常量名,否则报异常//执行流程//1.根据输入的“AUTUMN"到Season2的枚举对象去查找//2.如果找到了就返回,没有就报错Season2 autumn1 = Season2.valueOf("AUTUMN");System.out.println("autumn1=" + autumn1);System.out.println(autumn == autumn1);//compareTo:比较两个枚举常量,比较的就是编号//1.把Season2.AUTUMN枚举对象的编号和Season2.SPRING枚举对象的编号进行比较//2.结果  两编号相减System.out.println(Season2.AUTUMN.compareTo(Season2.SPRING));}
}enum Season2{//1.使用关键字eum来实现枚举类//2.public static final Season SPRING = new Season("春天","温暖");// SPRING("春天","温暖");即常量名(实参列表)//3.如果有多个常量(对象).使用,号间隔即可//4.如果使用enum实现枚举,要求将定义常量对象写在前面,枚举对象必须放在枚举类的行首//5.如果使用的是无参构造器创建常量对象则可以使用What,可以省略()SPRING("春天","温暖"),AUTUMN("秋天","凉爽");//SUMMER("夏天","炎热"), What();//调用无参构造器,或Whatprivate String name;private String desc;//定义了四个对象
/*  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 WINNER = new Season("冬天","寒冷");*/private Season2() {}private Season2(String name, String desc) {this.name = name;this.desc = desc;}public String getName() {return name;}//2.去掉set相关方法,只读不修改,防止属性被修改/*public void setName(String name) {this.name = name;}*/public String getDesc() {return desc;}@Overridepublic String toString() {return "Season{" +"name='" + name + '\'' +", desc='" + desc + '\'' +'}';}/*public void setDesc(String desc) {this.desc = desc;}*/
}
1)说明

1.当使用enum关键字开发一个枚举类时,默认会继承Enum类

2.将传统的

public static final Season SPRING = new Season("春天","温暖");  简化成 

SPRING("春天","温暖");  这里必须知道调用的是哪个构造器

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

4.当有多个枚举对象时,使用,号间隔,最后一个分号结尾

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

2)enum常用方法的使用

1.toString:Enum类已经重写过,返回的是当前对象名,子类可以重写该方法,用于返回对象的属性信息

2.name:返回当前对象名(常量名),子类中不能重写

3.ordinal:返回当前对象的位置号,默认从0开始

4.values:返回当前枚举类中所有的常量

5.valueOf:将字符串转换成枚举对象,要求字符串必须为已有的常量名,否则报异常

6.compareTo:比较两个枚举常量,比较的是编号

public class Enumeration02 {public static void main(String[] args) {//使用Season2枚举类演示方法Season2 autumn = Season2.AUTUMN;//输出枚举对象的名称System.out.println(autumn.name());//输出该枚举对象的次序/编号,从0开始编号System.out.println(autumn.ordinal());//values()返回枚举对象,Season[]Season2[] values = Season2.values();for(Season2 season : values){//增强for循环//依次从数组中取出System.out.println(season);}//valueOf():将字符串转换成枚举对象,要求字符串必须为已有的常量名,否则报异常//执行流程//1.根据输入的“AUTUMN"到Season2的枚举对象去查找//2.如果找到了就返回,没有就报错Season2 autumn1 = Season2.valueOf("AUTUMN");System.out.println("autumn1=" + autumn1);System.out.println(autumn == autumn1);//compareTo:比较两个枚举常量,比较的就是编号//1.把Season2.AUTUMN枚举对象的编号和Season2.SPRING枚举对象的编号进行比较//2.结果  两编号相减System.out.println(Season2.AUTUMN.compareTo(Season2.SPRING));}
}

3.使用细节

(1)使用enum关键字后,就不能再继承其他类了,因为enum会隐式继承Enum,而Java是单继承机制

(2)枚举类和普通类一样,可以实现接口,形式如下:

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

package com.figiting.enum_;/*** @version 1.0* @autor 疯小丢*/
public class EnumDetail {public static void main(String[] args) {Music.CLASSICMUSIC.playing();}
}class A {}
//1.使用enum关键字后就不能再继承其它类,因为enum会隐式继承Enum,而Java是单继承机制
//enum Season3 extends A {
//
//}
//2.enum实现的枚举类仍然是一个类,所以还是可以实现接口
interface  IPlaying {public  void playing();
}enum Music implements IPlaying {CLASSICMUSIC;public void playing(){System.out.println("播放好听的音乐...");}
}

二、注解

1.初步理解

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

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

(3)在JavaSE中,注解的使用目的比较简单,例如标记过的时的功能,忽略警告等,在JavaEE中注解占据更重要的角色,例如用来配置应用程序的任何切面,代替JavaEE旧版中所遗留的繁冗代码和XML配置等

2.基本介绍

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

3.基本的Annotation应用案例

(1)@Override

限定某个方法,重写父类方法,该注解只能用于方法

使用说明:
package com.figiting.annotation_;/*** @version 1.0* @autor 疯小丢*/
public class Override {public static void main(String[] args) {}
}class Father{public void fly() {System.out.println("Father fly...");}
}class Son extends Father{//1. @Override注解放在fly方法上,表示子类fly方法重写了父类的fly//2. 这里如果没有写@Override,还是重写了父类的fly//3. 如果写了,编译器就会检查该方法是否真的重写了父类的方法//如果重写了则编译通过,如果没有构成重写,则编译错误//即进行语法校验//4.@Override定义,@interface表示注解类//public @interface Override {//}@java.lang.Overridepublic void fly() {System.out.println("Son fly...");}
}

1)@Override 表示制定重写父类的方法,如果父类没有fly方法,则不会报错

2)如果不写@Override注解,而父类仍有public void fly(){},仍然构成重写

3)如果写了,编译器就会检查该方法是否真的重写了父类的方法,如果重写了则编译通过,如果没有构成重写,则编译错误。即进行语法检验

4)@Override只能修饰方法,不能修饰其他类,包,属性等

5)注解源码:

(2)@Deprecated

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

package com.figiting.annotation_;/*** @version 1.0* @autor 疯小丢*/
public class Deprecated_ {public static void main(String[] args) {A a = new A();a.hi();System.out.println(a.n1);}
}//1.@Deprecated 修饰某个元素,表示该元素已经过时
//2.即不再推荐使用,但是仍然可以使用
//3.@Deprecated类的源码
//4.可以修饰方法、类、字段、包、参数等
//5.可以做版本升级过度使用
@Deprecated
class A {public int n1 = 10;public void hi(){}
}

注解源码:

(3)@SuppressWarnings

抑制编译器警告

package com.figiting.annotation_;import java.util.ArrayList;
import java.util.List;/*** @version 1.0* @autor 疯小丢*/
public class SuppressWarnings_ {//1.当我们不希望看到这些警告时,可以使用SuppressWarnings注解来抑制警告信息//2.在{"all"}中,可以写入希望抑制(不显示)的警告信息//3//4.关于SuppressWarnings作用范围和放置的位置有关//比如@SuppressWarnings放置在main方法,则抑制警告范围就是main//5.源码//(1)放置的位置就是 TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE//(2)该注解类有数组String[] value();设置一个数组,比如{"rawtypes","unchecked","unused"}@SuppressWarnings({"rawtypes","unchecked","unused"})public static void main(String[] args) {List list = new ArrayList();list.add("");list.add("");list.add("");int i;System.out.println(list.get(1));}
}
可以指定的警告类型

1.all,抑制所有警告

2.cast,抑制与强制转型作业相关的警告

3.dep-ann,抑制与淘汰注释相关的警告

4.deprecation,抑制与淘汰相关警告

5.fallthrough,抑制与switch陈述式中遗漏break相关的警告

6.finally,抑制与未传回finally区块相关的警告

7.hiding,抑制2与隐藏变数的区域变数相关的警告

8.incomplete-switch,抑制与switch陈述式(enum case)中遗漏项目相关的警告

9.javadoc,抑制与javadoc相关的警告

10.nls,抑制与非nls字串文字相关的警告

11.rawtypes,抑制与使用raw类型相关的警告

12.resource,抑制与使用Closeable类型的资源相关的警告

13.restriction,抑制与使用不建议或禁止参照相关的警告

14.serial,抑制与可序化的类别遗漏serialVersionUID栏位相关的警告

15.static-access,抑制与静态存取不正确相关的1警告

16.static-method,抑制与可宣告为static的方法相关的警告

17.super,抑制与置换方法相关但不含super呼叫的警告

18.synthetic-access,抑制与内部类别的存取未最佳化相关的警告

19.sync-override,抑制因为置换同步方法而遗漏同步化的警告

20.unchecked,抑制与未检查的作业相关的警告

21.unqualified-field-access,抑制与栏位存取不合格相关的警告

22.unused,抑制与未用的程式码及停用的程式码相关的警告

生成@SupperssWarnings时直接点击左侧的黄色提示就可以选择,注意可以指定生成的位置

4.元注解

(1)基本介绍

JDK的元注解用于修饰其他Annotation

元注解本身作用不大,但要清楚它是干什么的

(2)种类

1)@Retention 注解
1.说明

只能用于修饰一个Annotation定义,用于指定该Annotation 可以保留多长时间,
@Rentention包含一个RetentionPolicy类型的成员变量,使用@Rentention
时必须为该value成员变量指定值

2.@Retention的三种值

1)RetentionPolicy.SOURCE:编译器使用后,直接丢弃这种策略的注释
2) RetentionPolicy.CLASS:编译器将把注释记录在class文件中,当运行Java程
序时,JVM不会保留注解。这是默认值
3)RetentionPolicy.RUNTIME:编译器将把注释记录在class文件中,当运行
Java程序时,JVM会保留注释.程序可以通过反射获取该注释

2)@Target
基本说明

用于修饰Annotation定义,用于指定被修饰的Annotation能用于修饰哪
些程序元素.@Target 也包含一个名为value的成员变量。

3)@Documented
基本说明

@Documented:用于指定被该元 Annotationi修饰的 Annotation类将被
javadoc 工具提取成文档,即在生成文档时,可以看到该注释。
说明:定义为Documented的注解必须设置Retention值为RUNTIME。

4)@Inherited
基本说明

被它修饰的Annotation将具有继承性,如果某个类使用了被@Inherited修饰
的Annotation,则其子类将自动具有该注解

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/921900.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/921900.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

高效计算的源泉:深入浅出冯诺依曼模型与操作系统的管理艺术 —— 构建稳定、高效的应用基石 【底层逻辑/性能优化】

♥♥♥~~~~~~欢迎光临知星小度博客空间~~~~~~♥♥♥ ♥♥♥零星地变得优秀~也能拼凑出星河~♥♥♥ ♥♥♥我们一起努力成为更好的自己~♥♥♥ ♥♥♥如果这一篇博客对你有帮助~别忘了点赞分享哦~♥♥♥ ♥♥♥如果有什么问题可以评论区留言或者私信我哦~♥♥♥ ✨✨✨✨✨✨个人…

性能测试-jmeter9-逻辑控制器、定时器压力并发

课程:B站大学 记录软件测试-性能测试学习历程、掌握前端性能测试、后端性能测试、服务端性能测试的你才是一个专业的软件测试工程师 性能测试-jmeter逻辑控制器、定时器妙用IF控制器**IF 控制器的作用**循环控制器循环控制器的作用ForEach控制器ForEach 控制器的作用…

T:线段树入门(无区间更新)

线段树.线段树介绍.线段树框架.理解线段树.图式整个过程.线段树代码逐层解析.代码汇总.leetcode练习.线段树介绍 线段树(SegmentTree)\;\;\;\;\;\;\;\;线段树(SegmentTree)线段树(SegmentTree) is 用于高效处理区间查询和单点修改的数据结构,和树状数组很像&#xf…

【ISP】Charlite工具实操

实习一周了&#xff0c;参与了客观拍摄和测试&#xff0c;复习一下nv工具 BLACK LEVEL&#xff08;黑电平&#xff09; eg&#xff1a; $ nv_ob 0 in_dir <input directory> out_name <ob file> nv_ob 0 in_dir D:\study\nvraw\ob1 out_name D:\study\nvraw\my_out…

普蓝机器人 AutoTrack-IR-DR200 外设配置全指南

为什么外设配置对机器人研究如此重要&#xff1f;在当今机器人技术飞速发展的时代&#xff0c;高校学生研究团队正成为创新的重要力量。无论是参加机器人竞赛、开展毕业设计&#xff0c;还是进行学术研究&#xff0c;正确配置和使用外设设备都是成功的关键。尤其学生组装一个服…

8、Python性能优化与代码工程化

学习目标&#xff1a;掌握Python程序性能分析和优化的通用方法&#xff0c;建立工程化开发的规范意识&#xff0c;为后续AI项目开发奠定坚实的编程基础在数据科学和AI开发中&#xff0c;代码性能往往决定了项目的可行性。一个处理时间从几小时缩短到几分钟的优化&#xff0c;可…

【算法--链表】117.填充每个节点的下一个右侧节点指针Ⅱ--通俗讲解

通俗算法讲解推荐阅读: 【算法–链表】83.删除排序链表中的重复元素–通俗讲解 【算法–链表】删除排序链表中的重复元素 II–通俗讲解 【算法–链表】86.分割链表–通俗讲解 【算法】92.翻转链表Ⅱ–通俗讲解 【算法–链表】109.有序链表转换二叉搜索树–通俗讲解 【算法–链…

分词器(Tokenizer)总结(89)

分词器(Tokenizer)总结 分词器(Tokenizer) 分词器的词表(vocabulary)长度通常短于模型嵌入层(embedding layer)的长度。 结束标记(EOS token)应仅用于标记文本结尾,不可用于其他用途。 填充标记(PAD token)通常未预先定义,但你仍可能需要用到它: 对于生成式模型…

19 webUI应用中 Controlnet精讲(05)-图像修复与编辑

前面的篇章已经详细讲解了线条约束、三维关系与空间深度、人体姿态等几类controlnet的功能与应用&#xff0c;本节内容将对通过controlnet对图像修复与编辑进行讲解。 通过controlnet也可以对图片进行编辑、重绘及放大等操作&#xff0c;具体包括Recolor、Inpaint、Tile等&…

消息推送的三种常见方式:轮询、SSE、WebSocket

摘要&#xff1a;本文介绍消息推送的三种常见方式&#xff1a;轮询&#xff08;定时请求&#xff0c;易增负担&#xff09;与长轮询&#xff08;阻塞请求至有数据 / 超时&#xff0c;减少请求&#xff09;、SSE&#xff08;HTTP 单向实时传输&#xff0c;纯文本、自动重连&…

论文阅读:ACL 2024 Stealthy Attack on Large Language Model based Recommendation

总目录 大模型相关研究&#xff1a;https://blog.csdn.net/WhiffeYF/article/details/142132328 https://arxiv.org/pdf/2402.14836 https://www.doubao.com/chat/19815566713551106 文章目录速览攻击方法速览一、攻击核心目标与前提1. 核心目标2. 攻击前提二、模型无关的简单…

自动驾驶中的传感器技术43——Radar(4)

本文对目前毫米波雷达中的天线设计进行比较全面的罗列&#xff0c;并进行简单的设计评述 1、实际设计案例 图1 涵盖能宽窄覆盖的天线设计&#xff08;无俯仰分辨率&#xff09;图2 Bosch前雷达的天线设计&#xff08;有俯仰的分辨率但比较弱&#xff0c;也涵盖了扩展覆盖&…

使用反转法线材质球,实现切换天空盒相同的功能,优点:包体变小

切换天空盒第一步先把SKY 天空球资源导入到工程里&#xff0c; 第二步&#xff1a;天空球文件下的SKY预制件拖入到场景里 第三步 选着SKY材质球&#xff0c;拖入自己的全景图片(图片分辨率不能超过5000*5000&#xff0c;否则手机无法显示) 如果并没有效果&#xff0c;看看图…

真正有效的数据指标体系应该长什么样?

真正有效的数据指标体系应该长什么样&#xff1f;为什么大多数企业的指标体系都是"花架子"&#xff1f;真正有效的指标体系应该长什么样&#xff1f;从数据到洞察&#xff1a;让指标真正"活"起来结语在这个人人都在谈数字化转型的时代&#xff0c;企业就像…

分布式专题——6 Redis缓存设计与性能优化

1 多级缓存架构2 缓存设计 2.1 缓存穿透 2.1.1 简介缓存穿透是什么&#xff1f;当查询一个根本不存在的数据时&#xff0c;缓存层和存储层都不会命中。正常逻辑下&#xff0c;存储层查不到数据就不会写入缓存层。这会导致&#xff1a;每次请求这个不存在的数据&#xff0c;都要…

一文了解大模型压缩与部署

一文了解大模型压缩与部署&#xff1a;从 INT4 量化到 MoE&#xff0c;让大模型跑在手机、边缘设备和云端&#x1f3af; 为什么需要模型压缩与部署&#xff1f;你训练了一个强大的大模型&#xff08;如 Qwen-72B、LLaMA-3-70B&#xff09;&#xff0c;但在部署时发现&#xff1…

新手向:中文语言识别的进化之路

自然语言处理&#xff08;NLP&#xff09;技术正在以前所未有的速度改变我们与机器的交互方式。根据Gartner最新报告显示&#xff0c;全球NLP市场规模预计在2025年将达到430亿美元&#xff0c;年复合增长率高达21%。而中文作为世界上使用人数最多的语言&#xff08;全球约15亿使…

LeetCode100-206反转链表

本文基于各个大佬的文章上点关注下点赞&#xff0c;明天一定更灿烂&#xff01;前言Python基础好像会了又好像没会&#xff0c;所有我直接开始刷leetcode一边抄样例代码一边学习吧。本系列文章用来记录学习中的思考&#xff0c;写给自己看的&#xff0c;也欢迎大家在评论区指导…

uniapp开源多商户小程序商城平台源码 支持二次开发+永久免费升级

在电商行业竞争日益激烈的今天&#xff0c;拥有一个功能强大、灵活可拓展的多商户小程序商城至关重要。今天给大家分享一款 uniapp 开源多商户小程序商城平台源码&#xff0c;它不仅具备丰富的基础功能&#xff0c;还支持二次开发&#xff0c;更能享受永久免费升级服务&#xf…

使用脚本一键更新NTP服务器地址为自定义地址

【使用场景】 在银河麒麟桌面操作系统V10SP1-2303版本中使用脚本一键修改NTP服务器地址为自定义地址。 【操作步骤】 步骤1. 编写shell脚本 ```bash desktop2303@desktop2303-pc:~$ vim setntptimeserver.sh #!/bin/bashfunction modifykylinconf() { # 检查是否已存在目标配置…