JAVA注解详谈

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_37465188/article/details/86512251

前言

注解也是引入自JDK 1.5,自引入后它就成为了Java平台中非常重要的一部分。开发过程中,我们也时常在应用代码中会看到诸如@Override,@Deprecated这样的注解。
那么,为什么要引入注解,还是以前的答案:
不管是什么,只要是新入的东西,基本都有三个目的:

1.使得开发维护更便捷,减少程序员的开发工作量
2.提高程序运行效率
3.更加安全

所以很多人抱怨软件行业技术迭代快速,自己跟不上等等都是不对的。所有的技术迭代都只是减少我们的工作量,让我们的工作更加简单快捷。但是这种简单快捷是建立在我们的基础牢固,一步一个脚印的情况下。如果囫囵吞枣的学习,对于所有的知识都是一知半解,那么新东西的出现对于我们而言,只是增加了学习量,而不是减少了工作量。 所以,学习知识,还是慢慢来,比较快。 慢慢来,也会越来越有兴趣。
至于引入注解是为什么呢,请看下面分解。

什么是注解

Annotation(注释)其实就是元数据(MetaData,即解释数据的数据)

  • Annotation 其实就是代码里的特殊标记, 这些标记可以在编译, 类加载, 运行时被读取, 并执行相应的处理. 通过使用 Annotation, 程序员可以在不改变原有逻辑的情况下, 在源文件中嵌入一些补充信息.
  • Annotation 可以像修饰符一样被使用, 可用于修饰包,类, 构造器, 方法, 成员变量, 参数, 局部变量的声明, 这些信息被保存在 Annotation 的 “name=value” 对中.
  • Annotation 能被用来为程序元素(类, 方法, 成员变量等) 设置元数据

为什么引入注解

使用Annotation之前(甚至在使用之后),XML被广泛的应用于描述元数据。不知何时开始一些应用开发人员和架构师发现XML的维护越来越糟糕了。他们希望使用一些和代码紧耦合的东西,而不是像XML那样和代码是松耦合的(在某些情况下甚至是完全分离的)代码描述。
就如道家所讲,一阴一阳之谓道,整个宇宙规律都是如此,代码也是一个平衡的系统,所以就需要注解来平衡一下XML的松耦合。

下面我们通过一个例子来理解这两者(XML 和 Annotation)的区别。

假如你想为应用设置很多的常量或参数,这种情况下,XML是一个很好的选择,因为它不会同特定的代码相连。如果你想把某个方法声明为服务,那么使用Annotation会更好一些,因为这种情况下需要注解和方法紧密耦合起来,开发人员也必须认识到这点。

另一个很重要的因素是Annotation定义了一种标准的描述元数据的方式。在这之前,开发人员通常使用他们自己的方式定义元数据。例如,使用标记interfaces,注释,transient关键字等等。每个程序员按照自己的方式定义元数据,而不像Annotation这种标准的方式。

目前,许多框架将XML和Annotation两种方式结合使用,平衡两者之间的利弊。

使用注解

参考资料:
注解基础

猜你喜欢

转载自blog.csdn.net/qq_37465188/article/details/86512251