Java 注解(一):创建自定义注解

Java 注解

Java Annotations

什么是java注解


Java注解不属于代码的一部分,但用来给代码添加元数据(metadata). Java注解并不会直接对其所注解的代码运行产生操作.

作用


编译器说明

Java有三个內建注解,分别是@Deprecated @Override 和 @SuppressWarnings. 他们可以给编译器确认指令.例如@override注解告诉编译器被注解的方法被覆盖.

编译期指令:注解可以为编译器提供编译期指令.他们还可以被软件构建工具用于生成代码,XML文件等

执行期指令: 这种注解可以在代码运行期通过Java反射机制操作程序运行.

注解基础


注解以@开始,后面跟着注解的名字,字符@告诉编译器这是一个注解.
例如

@Overrite

@表明这是一个注解,Overrite是这个注解的名字.

哪里可以使用注解

注解可以应用于类,接口,方法和属性.例如下面是为方法添加注解

@Override
void myAnnotationsMethod(){
    //Do someting here
}

Java内建注解

Java有三个內建注解:

  • @Override
  • @Deprecated
  • @SuppressWarnings
  1. @override注解
    @override注解被用于在子类中覆盖父类的方法.这有助于增加代码的可读性,降低代码维护难度.例如,当改变父类方法的签名后,子类中没有做同步的函数签名修改的情况下
    * 如果子类中的覆盖方法使用了@override注解
    编译器将抛出编译错误.以便开发人员及时方便的发现问题
    * 如果子类中的覆盖方法没有使用该注解
    编译器在编译时会认为这个方法并不是覆盖的父类方法而是子类新增的方法,从而编译通过.而这并不是开发人员期望的结果.

例子

public class MyParentClass {

    public void justaMethod() {
        System.out.println("Parent class method");
    }
}


public class MyChildClass extends MyParentClass {

    @Override
    public void justaMethod() {
        System.out.println("Child class method");
    }
}
  1. @Deprecated注解
    表示被注解的元素不应该再被使用.例如
@Deprecated
public void oneDeprecatedMethod(){
    //Do something here
}
  1. @SuppressWarnings
    该注解告诉编译器忽略被注解元素编译时产生的警告信息.例如,当使用一个被@Deprecated注解的方法时,希望编译器忽略deprected警告,则可以使用如下的方式
@SuppressWarnings("depracation")
pulic void myNoWarningsMethod(){
    myObject.oneDeprecatedMethod();
}

创建自定义注解

示例:

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Documented
@Target(Element.METHOD)
@Inherited
@Retention(RetentionPolicy.RUNTIME)
public @interface MyCustomAnnotation{
    int age() default 18;
    String name();
    String author() default "LeoSun";
    String[] friendList();
    public enum Sex{
        MALE,FEMALE
    }
    Sex sex() default Sex.MALE;
}
  • 注解创建时使用 @interface annotationName 其中annotationName为自定义注解的名字.
  • 自定义注解使用元注解(meta-annotation)进行注解
  • 注解可以有元素,元素的形式类似于方法.但没有方法的实现部分.
  • 所有注解extends java.lang.annotation 接口,不能extends其他.
  • 包含默认值的元素,例如上例中的age,author等,在使用时可不赋值.例如
@MyCustomAnnotation(
name="LeoSun",
friendList="{"lili","xiaoming"}"
)
public classs myClass{
    //...
}

下面介绍自定义注解中使用到的四个元注解

  1. @Documentd
    在生成javadoc文档时,该注解会被生成到文档中.
  2. @Target
    指定该注解可被使用的位置.MyCustomAnnotation注解只能被使用在方法上.Target可使用的位置为

//注解方法
ElementType.METHOD
//注解包
ElementType.PACKAGE
//注解参数
ElementType.PARAMETER
//类,接口(包括注解)或枚举
ElementType.TYPE
ElementType.ANNOTATION_TYPE
//注解构造函数
ElementType.CONSTRUCTOR
//注解局部变量
ElementType.LOCAL_VARIABLE
//注解属性
ElementType.FIELD

如果注解没有使用@Target,则表明该注解可以使用在任何元素上.

  1. @Inherited
    表明被该注解所注解的类的所有子类都会继承该注解.例如
@MyCustomAnnotation
public class MyParentClass {
 ... 
}
public class MyChildClass extends MyParentClass {
 ... 
}

这里,MyParentClass使用了MyCustomAnnotation, MyChhildClass是MyParentClass的子类,因此,MyChhildClass也具有MyCustomAnnotation注解.

  1. @Retention
    表明被注解元素的生存期.有三种类型

//运行期有效,可被Java反射使用
RetentionPolicy.RUNTIME
//生成在.class文件中,程序运行期不可用
RetentionPolicy.CLASS
//被注解的元素在源代码文件中,既不会生成到class文件,在运行期也不可用
RetentionPolicy.SOURCE

注解创建完成,下一篇讲述如何处理自定义的注解.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352

推荐阅读更多精彩内容