java 注解

注解

什么是注解

  • 不是程序本身,可以对程序作出解释
  • 可以被其他程序读取
  • 格式:@注释名,还可以添加一些参数值,例如@SuppressWarnings(value=“unchecked”)
  • 可以附加在package, class, method, field等上面

内置注解

  • @Override
  • @Deprecated
  • @SuppressWarnings

元注解

负责注解其他注解

  • @Target:用于描述注解的使用范围
  • @Retention:用于描述注解的生命周期,表示需要在什么级别保存该注释信息
    • (SOURCE < CLASS < RUNTIME)
  • @Documented:说明该注解将被包含在javadoc中
  • @Inherited:说明子类可以继承父类中的该注解

自定义注解

package com.nocilantro.Annotation;

import java.lang.annotation.*;

/**
 * 测试元注解
 */
@MyAnnotation
public class Test02 {

    @MyAnnotation
    public void test() {
    }

}

// 表示注解可以用在哪里
@Target(value = {ElementType.METHOD, ElementType.TYPE})
// 表示注解在什么地方还有效
// SOURCE只在源码中有效
// CLASS在CLASS文件中还有效
// RUNTIME在什么地方都有效
@Retention(value = RetentionPolicy.RUNTIME)
// 表示注解将被包含在javadoc中
@Documented
// 子类可以继承父类的注解
@Inherited
@interface MyAnnotation {

}
package com.nocilantro.Annotation;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * 自定义注解
 */
public class Demo03 {
    @MyAnnotation2(name = "Leo", schools = "MIT") // 如果没有默认值,必须给注解赋值
    public void test() {}

    @MyAnnotation3("xixi") // 可以省略value =
    public void test02(){}
}

@Target({ElementType.TYPE, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@interface MyAnnotation2{
    // 注解的参数:参数类型,参数名
    String name() default "Qiuqiu";
    int age() default 0;
    int id() default -1;

    String[] schools() default "UW";
}

@Target({ElementType.TYPE, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@interface MyAnnotation3 {
    String value(); // 只有一个参数成员是,使用value作为参数名,使用该注解时可以直接定义value
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值