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. DHCP服务器怎么设置怎么启动

    DHCP:动态主机配置协议,服务器用于为网络中的客户端自动分配IP地址.这种方法避免了由于手动配置IP地址导致的IP地址冲突问题,同时也减少了网络管理员的工作量. 工具/原料 在配置DHCP服务器时, ...

  2. 邮件解析 CNAME记录 A记录

    域名配置 示例发信配置请至域名 service.i-test.cn DNS服务提供商处添加TXT记录,并保持SPF记录正确,否则会无法发信.*1.所有权验证类型 主机记录 主域名 记录值 状态TXT ...

  3. elasticsearch 5.1 认证过期 (your license has expired)

    首先说一下License过期后的状况: if 设置了登录认证,license过期后将无法登录(无法填入用户名密码,下方给出报错,license过期): if 没有设置登录认证,打开kibaba界面中M ...

  4. CentOS 7命令行安装GNOME、KDE图形界面(成功安装验证)

    来源:cnblogs.com/Amedeo  作者:Amedeo 正文 CentOS 7 默认是没有图形化界面的,但我们很多人在习惯了 Windows 的图形化界面之后,总是希望有一个图形化界面从而方 ...

  5. Emqtt集群搭建

    1 Emqtt简单搭建 1.1  介绍:EMQ:EMQ 2.0,号称百万级开源MQTT消息服务器,基于Erlang/OTP语言平台开发,支持大规模连接和分布式集群,发布订阅模式的开源MQTT消息服务器 ...

  6. Django CORS跨域资源共享

    1,什么是CORS ​ 允许浏览器向跨源(协议 + 域名 + 端口)服务器发出XMLHttpRequest请求,从而克服了AJAX只能同源使用的限制 2,特点 ​ 1,浏览器自动完成(在请求头中加入特 ...

  7. JAVA线程初体验

    线程的创建 线程的启动和停止 /** * 演员类 继承Thread类 * @author Administrator * */ public class Actor extends Thread { ...

  8. 爬虫之requests模块的使用

    requests模块 概念:基于网络请求的模块 作用:用来模拟浏览器发请求,从而实现爬虫 环境安装:pip install requests 编码流程: 指定url 发起请求 获取响应数据 持久化存储 ...

  9. 18、NumPy——矩阵库(Matrix)

    NumPy 矩阵库(Matrix) NumPy 中包含了一个矩阵库 numpy.matlib,该模块中的函数返回的是一个矩阵,而不是 ndarray 对象. 一个 的矩阵是一个由行(row)列(col ...

  10. Tensorflow机器学习入门——MINIST数据集识别

    参考网站:http://www.tensorfly.cn/tfdoc/tutorials/mnist_beginners.html #自动下载并加载数据 from tensorflow.example ...