注解-自定义注解
自定义注解关键字:使用@interface自定义注解时﹐自动继承了java.lang.annotation.Annotation接口
分析: interface用来声明一个注解﹐格式: public @interface 注解名{定义内容}√其中的每一个方法实际上是声明了一个配置参数. √方法的名称就是参数的名称. √返回值类型就是参数的类型(返回值只能是基本类型,Class , String , enum ).√可以通过default来声明参数的默认值 √如果只有一个参数成员,一般参数名为value √注解元素必须要有值﹐我们定义注解元素时,经常使用空字符串,0作为默认值.
//自定义注解 public class Main { //注解可以显示赋值,如果没有定义默认值,我们就必须给注解赋值 @MyAnnolalion2(name="Holle")//正常情况下我们只需要为没有设置默认值的属性赋值即可 public void test(){} } //定义一些元注解 @Target({ElementType.TYPE,ElementType.METHOD})//可以作用在类中及方法中,TYPE:类作用域,METHOD:方法作用域 @Retention(RetentionPolicy.RUMTINE)//注解有效区域 @interface MyAnnolalion2{ //这个是注解的参数不是方法,注解的参数:参数类型+参数名(); String name() default "";//default:设置默认值 int age().default 0; int id default-1;//如果默认值为-1代表不存在 String[] schools() default ["中国","大学"]; } //这两句元注解是常规要写的 Target({ElementType.TYPE,ElementType.METHOD}) @Retention(RetentionPolicy.RUMTINE) @interface MyAnnolalion3{ String value();//自定义注解时,只有一个值时,建议使用,value命名,因为这样在调用注解可以省略了value="",可以直接写“” }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!