JDK的注解

内置注解

@Override:定义再java.lang.Override中,此注解只使用于修辞方法,表示一个方法声明打算重写超类中的另一个方法声明

@Deprecated:定义在java.lang.Deprecated中,此注解可以用于修辞方法、属性、类,表示声明被标注的东西已经过时了,不鼓励程序员使用这样的元素,通常是因为它很危险或者存在更好的选择,现在已经被新版本淘汰了

@SuppressWarnings:定义在java.lang.SuppressWarnings中,用来抑制编译时候的报警信息,需要添加固定的参数,

  • @SuppressWarnings("all")、
  • @SuppressWarnings("unchecked")、
  • @SuppressWarnings(value={"unchecked","deprecation"})等等

元注解

元注解的作用就是负责注解其他注解,Java定义了4个标注的meta-annotation类型,他们被用来提供对其他annotation类型作说明

这些类型和它们所支持的类在java.lang.annotation包中可以找到(@Target、@Retention、@Documented、@Inherited)

@Target:用于描述注解的使用范围(即:被描述的注解可以用在说明地方)

@Retention:表示需要在什么级别保存该注释信息,用于描述注解得生命周期(SOURCE<CLASS<RUNTIME)

@Document:说明该注解将被包含在javadoc中

@Inherited:说明子类可以继承父类中得该注解

自定义注解:使用@Interface自定义注解时,自动继承java.lang.annotation.Annotation接口

分析:

  • @Interface用来声明一个注解,格式:public @Interface 注解名{定义内容}
  • 其中的每一个方法实际上是声明了一个配置参数
  • 方法的名称就是参数的名称
  • 返回值类型就是参数的类型(返回值只能是基本类型Class,String,enum)
  • 可以通过default来声明参数的默认值
  • 如果只有一个参数成员,一般参数名为value
  • 注解元素必须要有值,我们定义注解元素时,经常使用空字符串,0作为默认值
package com.cbbpp;

import java.lang.annotation.*;

@MyAnnotation
public class test {
    //注解可以显示赋值,如果没有默认值,我们就必须给注解赋值
    @MyAnnotation(name="tubos",school = {"师范","工大"})
    public void test1(){

    }
}

//定义一个注解
//Target表示我们自定义得注解可以用在哪些地方
@Target(value = {ElementType.TYPE,ElementType.METHOD})
//Retention表示我们得注解在什么地方还有效,(SOURCE<CLASS<RUNTIME)
@Retention(value = RetentionPolicy.RUNTIME)
//表示我们得自定义注解是否生成在JAVAdoc中
@Documented
//表示子类可以继承父类的注解
@Inherited
@interface MyAnnotation{
    //注解的参数:参数类型 + 参数名()
    String name() default;
    int age() default 0;
    int id() default -1;//如果默认值为-1,代表不存在

    String[] schools();
    String[] 性别() defailt {"男","女"};
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值