Annotation的目的主要是减少源代码和配置文件中的重复,增强系统的一致性,以免修改配置忘了修改代码
Annotation本意是要加强原配置与代码的自动联系(把原来的配置写进代码,提高修改的便捷),完全符合软件工程指导
个人认为对那些与代码不存在联系的信息最好还是写在配置文件中,这样修改是不至于要重新编译
最常见的annotation
● @Override: 用在方法之上,用来告诉别人这一个方法是改写父类的
● @Deprecated: 建议别人不要使用旧的API的时候用的,编译的时候会用产生警告信息,可以设定在程序里的所有的元素上.
● @SuppressWarnings: 暂时把一些警告信息消息关闭
● @Entity: 表示该类是可持久化的类
1. 只有一个参数的Annotation实现
package com.wei.peng.annotation;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
* @author WPeng
* @time 2011-2-17 下午02:01:05
* @email pengwei841221@126.com
*/
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface MyAnnotation1 {
String value();
}
2. 有两个参数的Annotation实现
package com.wei.peng.annotation;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
* @author WPeng
* @time 2011-2-17 下午02:01:12
* @email pengwei841221@126.com
*/
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface MyAnnotation2 {
String decription();
boolean isAnnotation();
}
3. Annotation实验类
package com.wei.peng.annotation;
/**
* @author WPeng
* @time 2011-2-17 下午02:00:57
* @email pengwei841221@126.com
*/
@MyAnnotation1("this is annotation1")
public class AnnotationDemo {
@MyAnnotation2(decription="this is annotation2", isAnnotation=true)
public void sayHello(){
System.out.println("Hello World!");
}
}
4.Annotation测试说明类
package com.wei.peng.annotation;
import java.lang.reflect.Method;
/**
* @author WPeng
* @time 2011-2-17 下午02:00:50
* @email pengwei841221@126.com
*/
public class TestAnnotation {
public static void main(String[] args){
try{
Class<?> cls = Class.forName("com.wei.peng.annotation.AnnotationDemo");
boolean flag = cls.isAnnotationPresent(MyAnnotation1.class);
if(flag){
System.out.println("判断类是annotation");
MyAnnotation1 annotation1 = cls.getAnnotation(MyAnnotation1.class);
System.out.println(annotation1.value());
/////////
Method method = cls.getMethod("sayHello");
flag = method.isAnnotationPresent(MyAnnotation2.class);
if(flag){
System.out.println("判断类是annotation");
MyAnnotation2 annotation2 = method.getAnnotation(MyAnnotation2.class);
System.out.println(annotation2.decription() + "\t" + annotation2.isAnnotation());
}
}
}catch (Exception e) {
// TODO: handle exception
}
}
}
实验结果,控制台打出如下信息:
判断类是annotation
this is annotation1
判断方法也是annotation
this is annotation2 true
MyAnnotation1中的@Target(ElementType.TYPE)
@Target里面的ElementType是用来指定Annotation类型可以用在哪些元素上的.例如:
TYPE(类型)、FIELD(属性)、METHOD(方法)、PARAMETER(参数)、CONSTRUCTOR(构造函
数)、LOCAL_VARIABLE(局部变量),、PACKAGE(包),其中的TYPE(类型)是指可以用在
Class,Interface,Enum和Annotation类型上。
MyAnnotation1中的@Retention(RetentionPolicy.RUNTIME)
RetentionPolicy 共有三种策略,分别为:
- SOURCE:这个Annotation类型的信息只会保留在程序源码里,源码如果经过了编译之后,Annotation的数据就会消失,并不会保留在编译好的.class文件里面
- CLASS:这个Annotation类型的信息保留在程序源码里,同时也会保留在编译好的.class文件里面,在执行的时候,并不会把这些信息加载到JVM中。注:默认策略为CLASS类型
- RUNTIME:表示在源码、编译好的.class文件中保留信息,在执行的时候会把这一些信息加载到JVM中去的
MyAnnotation1中的@Documented
目的就是将这一Annotation的信息显示在JAVA API文档上,如果没有增加@Documented的话,JAVA API文档上不会显示相关annotation信息
MyAnnotation1中的@interface
关键字,表示该类为Annotation定义
MyAnnotation1中的 String value();
表示有一个成员参数,名字为value,访问权为默认(default)修饰符,注意以下两点:
- 访问权只能用public和默认(default)修饰
- 参数成员只能用基本类型byte,short,char,int,long,float,double,boolean八种基本数据类型和String,Enum,Class,annotations等数据类型,以及这一些类型的数组
AnnotationDemo中的@MyAnnotation1("this is annotation1")
因为MyAnnotation1只有一个参数,因此可以直接在括号中写上value值。注:如果Annotation只有一个参数,则建议最好将该参数名称定义为value
TestAnnotation中的cls.isAnnotationPresent(MyAnnotation1.class)
判断该类是否使用了MyAnnotation1的注释
TestAnnotation中的MyAnnotation1 annotation1 = cls.getAnnotation(MyAnnotation1.class)
返回该类针对MyAnnotation1的注释
TestAnnotation中的method.isAnnotationPresent(MyAnnotation2.class)
判断该方法是否使用了MyAnnotation2的注释
分享到:
相关推荐
处理器通常通过实现`javax.annotation.processing.Processor`接口来实现。 2. 运行时反射:通过反射API,可以在运行时获取类、方法上的注解信息,执行相应的逻辑。 ```java public class AnnotationDemo { public...
在Nutz中使用Ioc-Annotation的入门教程 Nutz是一个轻量级的Java开发框架,它提供了强大的IoC(Inversion of Control)容器和AOP(Aspect-Oriented Programming)支持。本教程将引导您了解如何在Nutz中利用Ioc-...
这就是一个基本的Hibernate Annotation入门示例。通过这种方式,我们可以更方便地管理数据库操作,减少与数据库相关的代码量。同时,由于注解是类型安全的,因此可以降低因配置错误导致的问题。 在实际开发中,你还...
Java 注解(Annotation)是Java 5.0版本引入的一种元数据机制,它为代码提供了额外的信息,这些信息可以被编译器、JVM或工具用来执行特定的任务,如代码分析、验证、生成代码等。本文主要介绍了Java注解的基本概念、...
本自述文件只是一个快速入门文档。 您可以在找到更多详细的文档。 什么是Redis? Redis通常被称为数据结构服务器。 这意味着Redis通过一组命令提供对可变数据结构的访问,这些命令是使用带有TCP套接字和简单协议的...
ORB-SLAM2(中文注释版) 评论员: 作者: , , 和 ( ) 2017年1月13日:现在支持OpenCV 3和Eigen 3.3。 2016年12月22日:添加了AR演示(请参见第7节)。 ORB-SLAM2是用于单目,立体声和RGB-D相机的实时SLAM库...
- 通过 `<tx:annotation-driven/>` 标签或相应的 Java 配置启用 Spring 的事务管理功能,这样可以在 Service 层使用 `@Transactional` 注解来声明式地管理事务。 5. **使用 Repository 接口**: - 在 Service 层...
这个名为"nginx_1.6.2_Chinese_...这不仅有利于初学者入门,也有助于专业人士深入研究和定制Nginx,以满足特定的Web服务需求。对于想要提升自己在系统开源领域技能的开发者来说,这是一个不容错过的学习材料。
**基于Annotation的SpringMVC入门小例子** 在Java Web开发中,SpringMVC是一个非常流行的框架,它使得构建Web应用程序变得更加简洁和高效。本篇将详细介绍如何使用注解(Annotation)来配置和运行一个基本的...
在《Java Annotation入门》之后的这篇《重难点之JavaAnnotation手册》中,作者深入探讨了Annotation的概念、定义以及其在Java开发中的应用。 一、Annotation是什么? Annotation是一种在代码中添加的特殊注解,用于...
本篇文章将聚焦于MyBatis中的注解(Annotation)与XML配置的结合使用,旨在帮助开发者更深入地理解这一关键特性。 首先,MyBatis允许我们使用注解来简化Mapper接口的定义,无需编写XML映射文件。例如,我们可以在...
在《Java Annotation入门》的基础上,这篇手册深入探讨了Annotation的定义、使用和功能。 一、Annotation的本质 Annotation提供了一种附加信息到程序元素(如类、方法、变量等)的方式,这些信息被称为元数据。元...
### Spring Annotation 入门 #### 一、Spring 注解概述 Spring 框架自2.0 版本起引入了一系列注解支持,这极大简化了配置管理,并为开发提供了更为简洁灵活的方式。通过注解,可以将业务逻辑与配置分离,减少XML...
Java注解(Annotation)是Java语言的一个重要特性,它为元数据提供了强大的支持。元数据是关于数据的数据,可以用来提供额外的信息,如代码的解释、编译时或运行时的处理指令等。注解在Java中扮演着代码文档、编译器...
Java 注解(Annotation)是 Java 语言中的一个重要特性,它为程序员提供了元数据,即关于数据的数据。在本文中,我们将深入理解 Java 注解的基本概念、用途、工作方式以及如何使用它们。 首先,让我们了解为什么...
JSF+Spring+Hibernate(Annotation)的login小实例,建议入门的朋友看看,老鸟就免了,呵呵。环境:SQLSever2000+jdk5.0+spring2.0+hibernate3.2+jsf
Java 注解(Annotation)是 Java 语言中的一个重要特性,它允许程序员在源代码中嵌入元数据(metadata)。元数据是关于数据的数据,不直接影响程序的运行,但可以被编译器或运行时环境用来生成代码、执行验证、实现...