注解

来源:互联网 发布:中科信证券软件 编辑:程序博客网 时间:2024/06/09 14:23

概述

注解与注释,    注解,告诉编译器如何运行程序!    注释, 给程序员阅读,对编译、运行没有影响;注解作用,    1. 告诉编译器如何运行程序;    2. 简化(取代)配置文件   【案例后再看】

常用的注解

// 重写父类的方法    @Override    public String toString() {        return super.toString();    }    // 抑制编译器警告    @SuppressWarnings({"unused","unchecked"})    private void save() {        List list = null;    }    // 标记方法以及过时    @Deprecated    private void save1() {    }

自定义注解

通过自定义注解,可以给类、字段、方法上添加描述信息!

注解基本写法

/** * 自定义注解  (描述一个作者) */public @interface Author {    /**     * 注解属性     *    1. 修饰为默认或public     *    2. 不能有主体     */    String name();    int age();}

使用

@Author(name = "Jet", age = 30)    public void save() {    }

带默认值的注解

public @interface Author {    /**     * 注解属性     *    1. 修饰为默认或public     *    2. 不能有主体     */    String name();    int age() default 30;   // 带默认值的注解;  使用的时候就可以不写此属性值}

默认名称的注解

注解属性名称为value,这就是默认名称
public @interface Author {    // 如果注解名称为value,使用时候可以省略名称,直接给值    // (且注解只有一个属性时候才可以省略名称)    String value();}

使用

@Author("Jet")@Author(value = "Jet")
注解属性类型为数组:
public @interface Author {    String[] value() default {"test1","test2"};}

使用

@Author({""""})public void save() {}

元注解

表示注解的注解!

指定注解的可用范围

@Target({TYPE,     类FIELD,     字段METHOD,  方法PARAMETER,   参数CONSTRUCTOR, 构造器 LOCAL_VARIABLE  局部变量})

指定注解的生命周期

// 元注解 @Retention(RetentionPolicy.SOURCE)    注解只在源码级别有效@Retention(RetentionPolicy.CLASS)      注解在字节码即别有效  默认值@Retention(RetentionPolicy.RUNTIME)   注解在运行时期有效

注解反射

@Id@Author(remark = "保存信息!!!", age = 19)public void save() throws Exception {    // 获取注解信息: name/age/remark    // 1. 先获取代表方法的Method类型;    Class clazz = App_2.class;    Method m = clazz.getMethod("save");    // 2. 再获取方法上的注解    Author author = m.getAnnotation(Author.class);    // 获取输出注解信息    System.out.println(author.authorName());    System.out.println(author.age());    System.out.println(author.remark());}
0 0
原创粉丝点击