java基础

本文作者

15

1-2018

zho007

博客:

https://www.jianshu.com/u/e9cb5fd3aaa8

声明:本文由作者zho007授权发布,未经原作者允许请勿转载

看到上面蓝色字了吗,点下吧

前言

注解基本概念

我们在开发当中经常看到一些注解,例如override,Deprected等,这些注解再常见不过了,但是这些注解到底有什么作用呢?在spring 框架中大量的使用注解,那么它的工作原理又是什么呢?接下来我们来分析一下把。

概念

注解即元数据,就是源代码的元数据

注解在代码中添加信息提供了一种形式化的方法,可以在后续中更方便的 使用这些数据

Annotation是一种应用于类、方法、参数、变量、构造器及包声明中的特殊修饰符。它是一种由JSR-175标准选择用来描述元数据的一种工具。

作用

生成文档

跟踪代码依赖性,实现替代配置文件功能,减少配置。如Spring中的一些注解

在编译时进行格式检查,如@Override等

意义

注解之前,XML被广泛的应用于描述元数据,XML的维护越来越糟糕

在需要紧耦合的地方,比XML该容易维护,阅读更方便

在需要比较多参数设置时,使用xml更方便,而在将某个方法声明为服务时这种紧耦合的情况下,比较适合注解

XML是松耦合的,注解是紧耦合的

对于XML和注解的使用,要具体问题具体分析

Java的annotation没有行为,只能有数据,实际上就是一组键值对而已。通过解析(parse)Class文件就能把一个annotation需要的键值对都找出来

分类

按照运行机制来分类1.源码注解

只在源码中出现,编译成class文件就不存在了

2.编译时注解

注解在源码和编译中都存在 例如:Override,Deprected,SuppressWarnings

3.运行时注解

运行阶段起作用,甚至会影响运行逻辑的注解 例如spring框架中的@Autowired

按照来源来分类

来自Jdk的注解

来自第三方的注解

我们自己定义的注解

JDK注解

Override: 保证编译时 要重写方法的正确性

Deprected: 提示该方法已经过时

SuppressWarnings: 关闭特定警告信息

Java元注解

java中元注解有四个: @Retention @Target @Document @Inherited;它负责注解其他注解

@Retention:注解的保留位置

@Retention(RetentionPolicy.SOURCE) //注解仅存在于源码中,在class字节码文件中不包含

@Retention(RetentionPolicy.CLASS) // 默认的保留策略,注解会在class字节码文件中存在,但运行时无法获得,

@Retention(RetentionPolicy.RUNTIME) // 注解会在class字节码文件中存在,在运行时可以通过反射获取到

@Target: 注解的作用目标

@Target(ElementType.TYPE) //接口、类、枚举、注解

@Target(ElementType.FIELD) //字段、枚举的常量

@Target(ElementType.METHOD) //方法

@Target(ElementType.PARAMETER) //方法参数

@Target(ElementType.CONSTRUCTOR) //构造函数

@Target(ElementType.LOCAL_VARIABLE)//局部变量

@Target(ElementType.ANNOTATION_TYPE)//注解

@Target(ElementType.PACKAGE) ///包

@Document:说明该注解将被包含在javadoc中@Inherited:说明子类可以继承父类中的该注解自定义注解

概念就说这么多了,看多了没实践会有点懵,注解到底有什么用啊?注解是怎么使用的啊?接下来我们带着这一系列的疑问来做一个简单的例子。来梳理一下我们疑问

需求

我们模仿一下Hibernate的注解。只通过注解来简单实现它的核心功能

我们在数据库有一张user表。用于存储用户信息,然后我们现在对这张表进行查询功能。使用注解的方式来打印出不同条件来查询表的SQL语句。

准备

我们先准备好数据库中的表对应的bean对象

第一步:定义自己的注解

我们使用元注解对这个自己的注解来定义

表名对于的注解@Table

字段名对应的注解@Column

第二步:获取解析注解

获取对象的class

判断这个对象是否有表名的注解

获取表名注解的值

获取对象的所有属性

遍历所有属性判断是否有字段名的注解

获取各个字段名的注解的属性值

拼接sql语句

第三步 运行测试

测试代码

运行结果

select * from user where age=20,sex='男'

select * from user where name='张三',sex='男'

好了到了这里看来我们的自定义注解已经成功了。我们通过自己定义了两个注解Table和Column分别表示表明和属性名。然后再通过反射拿到对应的注解值和属性值,最后拼接成一条Sql。

注解的优缺点及与XML的比较

优:

方便,简洁,配置信息和 Java 代码放在一起,有助于增强程序的内聚性

若要对配置项进行修改,不得不修改 Java 文件,重新编译打包应用

缺:

分散到各个class文件中,维护性较差

配置项编码在 Java 文件中,可扩展性差

与XML比较:

简洁

没有XML配置更强大

不便于修改,不便于统一管理

  • 发表于:
  • 原文链接:http://kuaibao.qq.com/s/20180115B057WD00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。

同媒体快讯

扫码关注云+社区

领取腾讯云代金券