Java注解 - 为什么要使用注解

Posted xbq8080

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java注解 - 为什么要使用注解相关的知识,希望对你有一定的参考价值。

什么是注解

注解是 JDK 1.5 引入的功能。可以看作是对 一个 类/方法 的一个扩展的模版,每个 类/方法 按照注解类中的规则,来为 类/方法 注解不同的参数,在用到的地方可以得到不同的 类/方法 中注解的各种参数与值。

为什么要用注解

在 JDK 1.5 之前,Java 还没引入注解,这个时候如果我们要在 Spring 中声明一个 Bean,我们只能通过 XML 配置的方式。


public class DemoService{ }

<bean id="demoService" class="com.chenshuyi.DemoService"/>

但当有了注解,我们就可以不必写一个 XML 配置文件,可以直接在 DemoService 类上完成 Bean 的声明工作。


@Service
public class DemoService{ }

在表面上看来,我们通过注解的方式减少了一个XML配置文件,减少了开发代码量。但这真的是我们用注解而不用 XML 配置文件的原因吗?

在回答这个问题之前,我们再来回顾一下上面两种配置方式的特点:

  • 对于注解的方式。我们会发现它和代码结合得很紧密,所以注解比较适合做一些与代码相关度高的操作,例如将Bean对应的服务暴露出去。

  • 对于XML配置方式。我们会发现它将配置和代码隔离开来了所以XML配置更适合做一些全局的、与具体代码无关的操作,例如全局的配置等。

我相信很多人此前对于注解的认识就是方便开发。但事实上使用注解还是XML的判断标准应该是:该配置与代码的相关度。如果代码与配置相关度高,那么使用注解配置,否则使用XML配置。

注解和配置文件的比较

优点:

  1. 配置文件

    1. 遵循OCP开发原则,修改配置文件即可进行功能扩展(OCP 开闭原则 Open Closed Principle)

    2. 集中管理对象和对象之间的组合关系,易于阅读

  2. 注解

    1. 开发速度快

    2. 编译期间容易发现错误的出处

缺点:

  1. 配置文件

    1. 开发速度相对较慢

    2. 编译时很难检查出错误,运行中的错误很难定位,调试难度较大

  2. 注解

    1. 管理分散,基本每个类上都有

    2. 扩展功能时,没有遵循OCP开发原则

原文地址

注解的那些事儿(一)| 为什么要使用注解?

 

 

以上是关于Java注解 - 为什么要使用注解的主要内容,如果未能解决你的问题,请参考以下文章

java注释的java注解

如何在java web项目中添加自定义注解

什么是jpa注解,为什么要用注解,注解的意义是什么?

JAVA注解Annotation

注解的那些事| 为什么要使用注解?

SpringBoot Starter自定义注解 - 接口加解密