Java 注解——Java自己的配置文件

作者留言

哈喽,大家好,这是我的第一篇文章,我希望能够将所学习的知识进行归纳总结,并且与大家进行分享,接下来的一段时间会发布一系列JavaPython入门级别相关文章,并且是有体系的进行分享,夯实基础才能走的更远。希望大家不吝赐教!废话不多说,上干货!(如有涉及侵权处,请通过此平台联系本人删除)

前言

XML作为配置文件受到了大部分程序员的喜爱,但也有人会偏爱使用注解,其实个人觉得选择什么并不是重点,重点是要了解每一个技术诞生的本质;XML作为配置文件和代码是“松耦合”的代码描述,但是当XML配置文件过多时难以管理,同时IDE无法对XML配置文件的正确性进行校验,增加测试难度;而注解则是“紧耦合”的代码描述,它的目的是为了让应用更易于扩展的同时做到“零”配置。

一、什么是注解(Annotation)

注解即标注,是代码中的元数据(元数据:描述数据的数据),通过使用注解使得程序开发人员可以在不改变原有逻辑的情况下,在源文件中嵌入一些补充信息。请看以下代码片段:

图片1.png

对于初学者而言,其实经常会看到类似代码,心里会想@Override是什么鬼?其实它就是注解,在toString()方法上加入@Override,表示该注解下面的toString()方法必须重构父类方法。

看到这里我想有人就会认为接下来我会和大家介绍各种各样的注解了?!我偏不!

二、注解类型的语法标准

注解是Java中一种特殊的类型,接下来我们来看一下如何设计一个注解类型。

1、语法标准:

public   @interface   注解类型名称
{
    [   数据类型    变量名 ()    [   default  初始值   ];   ]
}

注:

1)"[ ]"中的内容可有可无,如果注解内部为空,则表示当前注解为标识注解。

2)注解中智能包含变量,不能包含方法。

3)注解是代码里的特殊标记,不可以单独使用,需要配合类或接口一起使用。

4)注解类型可以被用来为程序元素设置元数据(程序元素:类、方法、成员变量等)。

2、案例:设计注解类型Testable,由该注解标识的方法为可测试方法。该注解内部为空,表示该注解为标识注解。

public  @interface  Testable
{
}
public class Test

{

      @Testable

       public void info()

      {

              System.out.println(“我是info方法”);

      }

      public void info1()

      {

              System.out.println(“我是info1方法”);

      }

}

该类中加入@Testable注解,表示info方法为可被执行到的方法,仅仅是描述该方法是可被执行的方法而已,并不会有任何动态交互能力,如果想要达成该注解的作用必须要编写配套的Java应用程序,具体代码可参考如下代码。

大家可以思考,如果想要解析一个类的内部结构,我们可以通过什么技术来实现呢?

答案是:反射机制(接下来这一段有关于反射机制的相关内容不清楚的朋友们,按照下面代码进行调试,具体反射机制的相关知识稍后会发布)。

在java.lang.reflect包中常见的具有反射功能的工具类:Method(方法类)、Field(字段类)、Constructor(构造方法类)等。

以上这些工具类扩充了读取运行时注解的能力,即实现java.lang.annotation.AnnotatedElement接口;该接口是所有程序元素的父接口,该接口中提供了用于获取注解信息的相关方法。

  • getAnnotation(Class annotationClass):返回该程序元素上的、指定类型的注解,如果该类型的注解不存在,则返回null

  • Annotation [] getAnnotations():返回该程序元素上存在的所有注解。

  • Annotation是所有注解的父接口,默认情况下任何一个接口类型都实现该接口。

  • boolean isAnnotationPresent(Class annotationClass):判断该程序元素上是否包含指定类型的注解,存在则返回true,否则返回false。

代码参考:

解析Test类,并执行带有@Testable标识的方法。

import java.lang.reflect.Method;
public class UseTest
{
        public static void main(String[] args)throws Exception
        {
                  Class c=Class.forName(“Test”);
                  Object o=c.newInstance();
                  Method[] me=c.getDeclaredMethods();
                  for(Method temp:me)
                  {
                           if(temp.isAnnotationPresent(Testable.class))
                                   temp.invoke(o,new Object[0]);
                  }
         }
}

好了,到现在为止大家可以运行程序看一下效果了!

。。。。。。。

是不是特别无语(ˉ▽ˉ;)...,通过执行代码会发现程序并无任何结果,和我们想想的不太一样?!

欲知后事如何,请看下回分解!

三、总结:

接下来让我们总结一下朋友们所需要掌握的知识点吧。

1、XML与注解的区别

2、什么是注解

3、注解设计的语法标准

4、反射机制

5、java.lang.annotation.AnnotationElement的方法及作用

四、结束语

和大家说一下我匆匆结束的原因,第一次写文章,不知道发布出去的内容格式是什么样的,剩余相关知识请看下一篇文章,谢谢大家的支持。

以上就是Java 注解——Java自己的配置文件的详细内容,更多请关注其它相关文章!