Java注解Annotation机制说明和基础使用(为什么Annotation直接促进了框架的繁荣发展?)

本文主要是介绍Java注解Annotation机制说明和基础使用(为什么Annotation直接促进了框架的繁荣发展?),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、注解解决的问题【可忽略】

软件开发过程中,如何配置一直是一个重要的问题,对于一个框架,如果你不为它提供初始结构,它就无法理解你要做什么,自然无法工作。

1.问题:紧密贴合的代码和配置

在很久之前,开发者一般选择在代码段里,添加复杂的配置。
这样做,调试管理就是麻烦的问题。

2.问题:配置文件使得代码结构松散

后来,发展出配置文件来存放配置信息,比如经典的XML、纯文本。
举个例子,Spring框架最初使用XML文件配置Bean。
初学Spring时,想必大家都使用过Spring.xml或者properties.xml文件,来配置bean信息,或者配置数据库信息。
这种行为不仅看起来非常奇怪,初学者根本不能理解为什么配置一个xml文件,竟然能够影响到Spring的运行,还会使代码结构相当松散。
由于配置文件完全独立,在修改配置代码时,对于新加入项目的开发者,无法将配置信息和代码段应,更遑论修改

3.解决方案:注解标注配置信息

大家或多或少,应该都使用过一些注解,有的注解完全没有信息,比如@Component、@Data。
另外一些注解,我们需要配置信息,比如@MapperScan。
类的继承结构中,所有的自定义注解都是继承Annotation接口,当然,想深入理解原因,则需要学习Java语法机制,本文不赘叙。
对于无需信息的注解,其相当于一个标签,标记一个类、方法、属性或者接口,说明这个元素有这个标签,至于如何使用,则需要在编译、运行时依靠反射
对于需要信息的注解,我们同样使用反射机制,拿到注解标注的信息,从而进行相关开发。


分割线


二、注解的基础使用

这一部分,讲解了如何声明注解、如何通过反射得到注解使用注解

1.注解的声明和属性定义

注解的声明,和类、接口的声明非常类似,唯一的区别在于将class字段,改为@interface字段。
在注解中,可以定义一些属性,在Java语法中,这些属性相当于SpringMVC的Data类,只允许有Setter、Getter方法。【不过,注解本身也是为了解决数据配置问题诞生的】
如图所示:声明注解的方法

2.反射得到注解

我们说过,注解的本质是继承了Annotation接口,所以,注解本质上也是一个类(接口),既然是一个类,Java就会使用Class对象管理这个类。
这就是注解使用的前提。
使用Class,实例化某个类的Class对象,然后调用getAnnotations方法,可以得到这个类的所有注解,如下图所示。
拿到注解对象后,我们可以把它当成一个普通的Class对象来处理。
又因为这个类只有属性,并且,由于它是接口,这个属性在第一次赋值后就固定【static】。所以关键在于如何拿到它的属性
对每一个注解的属性,都会有一个与属性名相同的方法,来获得属性的值。【和getter方法类似,不过不用get字段

Class clazz = DataEntity.class;
// 得到所有的注解
Annotation[] annotations = clazz.getAnnotations();
// 得到AnnoReal这一类注解,实际开发中不会这么用
AnnoReal annotation = (AnnoReal) clazz.getAnnotation(AnnoReal.class);

3.使用演示:

// 我在AnnoReal注解类中,定义了value属性
System.out.println(annotation.value());

4.Java反射的核心Field、Method【简明介绍】

  1. name字段名,对于属性、方法来说,都会有字段名来唯一标识它。
  2. 指向对象的类:对于属性,定义它的类。【比如int a,a的Field则指向Integer】
  3. 对于Method:则有返回值类、参数类数组

三、通过方法拿到注解对象,或者拿到所有的注解数组。

clazz.getAnnotations();

实际开发中,因为我们不能确定哪个类实现了哪个注解,我们只能使用大量的if语句,来判断注解类型,从而决定怎么做。
当然,为了避免大量if语句造成的代码逻辑复杂,也可以使用策略模式

四、结语

注解为什么促进了框架发展?因为一个框架的学习需要很高的成本,注解的使用大大降低了理解难度,所以促进了。
我是蚊子码农,如有补充或者疑问,欢迎在评论区留言。个人的知识体系可能没有那么完善,希望各位多多指正,谢谢大家。

这篇关于Java注解Annotation机制说明和基础使用(为什么Annotation直接促进了框架的繁荣发展?)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1062373

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na