1.定义一个枚举类,后面自定义注解时使用

 package cn.tx.annotation.enums;
/**
* 定义枚举类型
* @author Administrator
*
*/
public enum HttpMethod { GET,POST,PUT,INPUT,DELETE;
}

2. 自定义一个注解 AnnoTest

 package cn.tx.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; import cn.tx.annotation.enums.HttpMethod; /**
* 1.自定义注解,自动实现了java.lang.Annotation接口
* @author Administrator
* 2.注解内部可以定义值,这里的值既不是属性,也不是方法
* 3.语法:数据类型 值的名字();
* 4.注解的意义:当非标识性注解(内部有值的注解)标注在方法上时,当方法被反射调用时,注解才有意义
* 5.@Retention 注解
* @Retention(RetentionPolicy.RUNTIME)
* @Target(ElementType.ANNOTATION_TYPE) public @interface Retention {
* RetentionPolicy value(); }
* RetentionPolicy:注解的策略
* RetentionPolicy.CLASS 表示这个注解能被编译到class文件里,但是运行时不参与运行
* 6.@Target注解——指示注解类型所适用的程序元素的种类
* @Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.ANNOTATION_TYPE)
public @interface Target {
ElementType[] value();
ElementType是一个枚举类型
}
* 7. @Target @Retention 只能用在注解的定义上面
* 8.@Documented 指明该注解将被包含在javadoc中
*/ //ElementType.METHOD,表示AnnoTest只能放在方法上面,不能放在类,属性等其他上面
@Target(value = { ElementType.METHOD,ElementType.TYPE })
@Retention(value = RetentionPolicy.RUNTIME)
public @interface AnnoTest { String value();//这里定义了值,在使用注解的地方,就得加上这个值 // Class[]/*String[]*/ location(); // HttpMethod method(); } // enum ElementType {
// /**类,接口,枚举声明 Class, interface (including annotation type), or enum declaration */
// TYPE,
// /**字段声明,包括枚举常量 Field declaration (includes enum constants) */
// FIELD,
// /**方法声明 Method declaration */
// METHOD,
// /** Parameter declaration */
// PARAMETER,
// /** 构造方法声明 Constructor declaration */
// CONSTRUCTOR,
// /**局部变量声明 Local variable declaration */
// LOCAL_VARIABLE,
// /**注解类型声明 Annotation type declaration */
// ANNOTATION_TYPE,
// /**包声明 Package declaration */
// PACKAGE
//}

3.  定义一个Claculate类,对方法使用自定义注解(前提是AnnoTest 注解 设置的@Target(value = { ElementType.METHOD,ElementType.TYPE })  ,也就是该注解能被使用在方法上面。)

 package cn.tx.annotation.test;

 import java.lang.annotation.ElementType;
import java.lang.annotation.Target; import cn.tx.annotation.AnnoTest; public class Caculate {
// @AnnoTest(value = "sss")
//AnnoTest注解中定义了@Target(value = { ElementType.METHOD,ElementType.TYPE })
//如果在属性a上面加@AnnoTest注解,会报:The annotation @AnnoTest is disallowed for this location
private int a; @AnnoTest(value = "相加的结果是:")
public int add(int a,int b){
return a+b;
} }

4. junit测试类:

 package cn.tx.annotation.test;

 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;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List; import cn.tx.annotation.AnnoTest;
import cn.tx.annotation.enums.HttpMethod; /**
* 常用的表标识性注解:@Test @Override @SuppressWarnings
*
* @author Administrator
*
*/
public class Test { @org.junit.Test
public void test() { } // @AnnoTest(value = "tst")
@Deprecated
// 过时,不建议使用的注解
public void method() { } /**
* @SuppressWarnings压制警告的注解 unchecked 不检查操作时的警告 rawtypes
* 原始类型,也就是不使用泛型,在定义的时候压制泛型的警告
*/
@SuppressWarnings( { "unchecked", "rawtypes" })
public void method1() {
@SuppressWarnings("unused")
List list = new ArrayList();// 不写泛型类型时,会出现黄色波浪线警告!
list.add("lisi");
} @org.junit.Test
// @AnnoTest(value = "test", location = { String.class }, method = HttpMethod.GET)
// 非标识性注解的意义在于方法被反射调用时
public void method3() { } @org.junit.Test
public void testEnum() {
System.out.println(HttpMethod.GET); //执行该方法,控制台打印GET
} @org.junit.Test
public void testAdd(){
new Caculate().add(3, 5); //正常调用,add方法上面的注解不会起作用
} @org.junit.Test
public void testAdd1(){
//获取Caculate类的Class对象,进而获得一个实例,然后获取声明的方法及方法上的注解
Class<?> clazz = Caculate.class;
try {
Object obj = clazz.newInstance();
//getFields()只能获取public的字段,包括父类的。getDeclaredFields()只能获取自己声明的各种字段,包括public,protected,private。
Method method = clazz.getDeclaredMethod("add", int.class,int.class);
//判断一个方法上面是否存在某个注解
boolean isPres = method.isAnnotationPresent(AnnoTest.class);
if(isPres){
//根据一个类获取注解 ,即获得@AnnoTest
AnnoTest annotation = method.getAnnotation(AnnoTest.class);
//获得注解上的值
String value = annotation.value(); //
//反射的方式调用add()方法
Object result = method.invoke(obj, 2,3);
System.out.println(value+result); //控制台输出结果为: 相加的结果是:5
//如果注解上的@Retention(value = RetentionPolicy.SOURCE),运行时时不会有结果的
} } catch (Exception e) {
e.printStackTrace();
} } }

Java自定义注解学习的更多相关文章

  1. java自定义注解学习(二)_注解详解

    上篇文章,我们简单的实现了一个自定义注解,相信大家对自定义注解有了个简单的认识,这篇,这样介绍下注解中的元注解和内置注解 整体图示 内置注解 @Override 重写覆盖 这个注解大家应该经常用到,主 ...

  2. java自定义注解学习(一)_demo小练习

    自定义注解 现在大家开发过程中,经常会用到注解. 比如@Controller 等等,但是有时候也会碰到自定义注解,在开发中公司的记录日志就用到了自定义注解.身为渣渣猿还是有必要学习下自定义注解的. 这 ...

  3. java自定义注解学习(三)_注解解析及应用

    上篇文章已经介绍了注解的基本构成信息.这篇文章,主要介绍注解的解析.毕竟你只声明了注解,是没有用的.需要进行解析.主要就是利用反射机制在运行时进行查看和利用这些信息 常用方法汇总 在Class.Fie ...

  4. java自定义注解学习(注解处理器)

    如果没有用来读取注解的方法和工作,那么注解也就不会比注释更有用处了.使用注解的过程中,很重要的一部分就是创建于使用注解处理器.Java SE5扩展了反射机制的API,以帮助程序员快速的构造自定义注解处 ...

  5. java自定义注解类

    一.前言 今天阅读帆哥代码的时候,看到了之前没有见过的新东西, 比如java自定义注解类,如何获取注解,如何反射内部类,this$0是什么意思? 于是乎,学习并整理了一下. 二.代码示例 import ...

  6. java自定义注解注解方法、类、属性等等【转】

    http://anole1982.iteye.com/blog/1450421 http://www.open-open.com/doc/view/51fe76de67214563b20b385320 ...

  7. java自定义注解实现前后台参数校验

    2016.07.26 qq:992591601,欢迎交流 首先介绍些基本概念: Annotations(also known as metadata)provide a formalized way ...

  8. java自定义注解知识实例及SSH框架下,拦截器中无法获得java注解属性值的问题

    一.java自定义注解相关知识 注解这东西是java语言本身就带有的功能特点,于struts,hibernate,spring这三个框架无关.使用得当特别方便.基于注解的xml文件配置方式也受到人们的 ...

  9. Java自定义注解的实现

    Java自定义注解的实现,总共三步(eg.@RandomlyThrowsException): 1.首先编写一个自定义注解@RandomlyThrowsException package com.gi ...

随机推荐

  1. CentOS-7.4(1708)release notes发行注记

    Red Hat Enterprise Linux 当前的最新版本是 7.3. Red Hat Enterprise Linux 7 当前仅支持 64 位CPU:64-bit AMD.64-bit In ...

  2. nginx配置-main

    nginx配置分为几大块: main (全局设置) events(nginx工作模式) http(http设置): upstream(负载均衡服务器设置),server(主机设置):location( ...

  3. import的项目结构不对

    问题如下,在我们新导入一个maven项目时,碰到这样的目录结构,总有点别扭,而且在运行Tomcat的时候,突然发现build i选项下面少了两个我们经常使用的两个选项 window  --Perspe ...

  4. CentOS 7.3 安装MySQL 5.7并修改初始密码

    在CentOS 7.3 下安装MySQL 5.7并修改初始密码,Windows下安装MySQL 5.7 见 http://www.linuxidc.com/Linux/2017-11/148521.h ...

  5. c++虚函数与重载

    class base{ public: virtual void f(int n){ cout << "base"<<endl; } }; class De ...

  6. (appium+python)UI自动化_02_appium启动手机app

    前提:需先安装配置好appium+python自动化环境,已配置好环境的小伙伴可以参考以下步骤启动Android app,具体步骤如下: 一.USB连接手机 (1)手机USB连接电脑 (2)手机打开开 ...

  7. 【ABAP系列】SAP ABAP基础-abap数据类型的解析整理

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP基础-abap数 ...

  8. poj3126Prime Path (BFS+素数筛)

    素数筛:需要一个数组进行标记 最小的素数2,所有是2的倍数的数都是合数,对合数进行标记,然后找大于2的第一个非标记的数(肯定是素数),将其倍数进行标记,如此反复,若是找n以内的所有素数,只需要对[2, ...

  9. jQuery基础--音乐视频操作

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  10. spring-第十八篇之spring AOP基于XML配置文件的管理方式

    1.在XML配置文件中配置切面.切入点.增强处理.spring-1.5之前只能使用XML Schema方式配置切面.切入点.增强处理. spring配置文件中,所有的切面.切入点.增强处理都必须定义在 ...