Java使用自定义注解实现为事件源绑定事件监听器操作示例

本文实例讲述了Java使用自定义注解实现为事件源绑定事件监听器操作。分享给大家供大家参考,具体如下:

一 定义注解

import java.lang.annotation.*;
import java.awt.event.*;
@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface ActionListenerFor
{
  // 定义一个成员变量,用于设置元数据
  // 该listener成员变量用于保存监听器实现类
  Class<? extends ActionListener> listener();
}

二 注解处理程序

import java.lang.reflect.*;
import java.awt.event.*;
import javax.swing.*;
public class ActionListenerInstaller
{
  // 处理Annotation的方法,其中obj是包含Annotation的对象
  public static void processAnnotations(Object obj)
  {
   try
   {
     // 获取obj对象的类
     Class cl = obj.getClass();
     // 获取指定obj对象的所有成员变量,并遍历每个成员变量
     for (Field f : cl.getDeclaredFields())
     {
      // 将该成员变量设置成可自由访问。
      f.setAccessible(true);
      // 获取该成员变量上ActionListenerFor类型的Annotation
      ActionListenerFor a = f.getAnnotation(ActionListenerFor.class);
      // 获取成员变量f的值
      Object fObj = f.get(obj);
      // 如果f是AbstractButton的实例,且a不为null
      if (a != null && fObj != null
         && fObj instanceof AbstractButton)
      {
        // 获取a注解里的listner元数据(它是一个监听器类)
        Class<? extends ActionListener> listenerClazz = a.listener();
        // 使用反射来创建listner类的对象
        ActionListener al = listenerClazz.newInstance();
        AbstractButton ab = (AbstractButton)fObj;
        // 为ab按钮添加事件监听器
        ab.addActionListener(al);
      }
     }
   }
   catch (Exception e)
   {
     e.printStackTrace();
   }
  }
}

三 测试注解程序

import java.awt.event.*;
import javax.swing.*;
public class AnnotationTest
{
  private JFrame mainWin = new JFrame("使用注解绑定事件监听器");
  // 使用Annotation为ok按钮绑定事件监听器
  @ActionListenerFor(listener=OkListener.class)
  private JButton ok = new JButton("确定");
  // 使用Annotation为cancel按钮绑定事件监听器
  @ActionListenerFor(listener=CancelListener.class)
  private JButton cancel = new JButton("取消");
  public void init()
  {
   // 初始化界面的方法
   JPanel jp = new JPanel();
   jp.add(ok);
   jp.add(cancel);
   mainWin.add(jp);
   ActionListenerInstaller.processAnnotations(this);   // ①
   mainWin.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
   mainWin.pack();
   mainWin.setVisible(true);
  }
  public static void main(String[] args)
  {
   new AnnotationTest().init();
  }
}
// 定义ok按钮的事件监听器实现类
class OkListener implements ActionListener
{
  public void actionPerformed(ActionEvent evt)
  {
   JOptionPane.showMessageDialog(null , "单击了确认按钮");
  }
}
// 定义cancel按钮的事件监听器实现类
class CancelListener implements ActionListener
{
  public void actionPerformed(ActionEvent evt)
  {
   JOptionPane.showMessageDialog(null , "单击了取消按钮");
  }
}

四 运行

更多java相关内容感兴趣的读者可查看本站专题:《Java面向对象程序设计入门与进阶教程》、《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》

希望本文所述对大家java程序设计有所帮助。

(0)

相关推荐

  • Java8新特性之重复注解(repeating annotations)浅析

    一.什么是重复注解 允许在同一申明类型(类,属性,或方法)的多次使用同一个注解 二.一个简单的例子java 8之前也有重复使用注解的解决方案,但可读性不是很好,比如下面的代码: 复制代码 代码如下: public @interface Authority {     String role();} public @interface Authorities {    Authority[] value();} public class RepeatAnnotationUseOldVersion

  • 全面解析Java中的注解与注释

    注解 一.什么是 Annotation? (注解 or 注释) Annotation, 准确的翻译应该是 -- 注解. 和注释的作用完全不一样. Annotation 是JDK5.0及以后版本引入的一个特性. 与类.接口.枚举是在同一个层次,可以成为java 的一个类型. 语法是以@ 开头 简单来说, 注释是程序员对源代码的类,方法,属性等做的一些记忆或提示性描述(比如这个方法是做什么用的),是给人来看的. 注解则是Java 编译器可以理解的部分,是给编译器看的. 举个简单的例子来看一下注解的使

  • Java基于反射机制实现全部注解获取的方法示例

    本文实例讲述了Java基于反射机制实现全部注解获取的方法.分享给大家供大家参考,具体如下: 一 代码 class Info{ //给mytoString方法加了2个内建Annotation @Deprecated @SuppressWarnings(value = "This is a waring!") public String mytoString(){ return "hello world"; } } class GetAnnotations{ publi

  • Java使用@Validated注解进行参数验证的方法

    目前项目中大部分代码进行参数验证都是写代码进行验证,为了提升方便性和代码的简洁性,所以整理了下使用注解进行参数验证.使用效果如下: // 要验证的实体类 @Data public class User implements Serializable { @NotBlank(message = "id不能为空!",groups = Update.class) protected String id = ""; @NotBlank(message = "商户i

  • java自定义注解接口实现方案

    java注解是附加在代码中的一些元信息,用于一些工具在编译.运行时进行解析和使用,起到说明.配置的功能. 注解不会也不能影响代码的实际逻辑,仅仅起到辅助性的作用.包含在 java.lang.annotation 包中. 1.元注解 元注解是指注解的注解.包括 @Retention @Target @Document @Inherited四种. 1.1.@Retention: 定义注解的保留策略 Java代码 复制代码 代码如下: @Retention(RetentionPolicy.SOURCE

  • Java中三种简单注解介绍和代码实例

    简单Java注解 JDK5提供的简单注解类型只有3个. 这三个都是用来预防错误或者进行提醒的,分别是: 1.Override 2.Deprecated 3.Suppresswarnings 需要注意,JDK5(另一个说法,Tiger)实际上并没有许多内置注解;相反,它允许核心Java支持注解特性的能力. JSR-175中严格规定它用来定义元数据功能. 需要由程序员编写自定义的注解类型,其他JSR标准也编写了一系列标准注解类型. 下面将用实例来深入讲解这三个简单注解. Override 注解 Ov

  • Java注解的Retention和RetentionPolicy实例分析

    本文实例讲述了Java注解的Retention和RetentionPolicy.分享给大家供大家参考,具体如下: 一 源码赏析 1 源码 @Documented @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.ANNOTATION_TYPE) public @interface Retention { RetentionPolicy value(); } public enum RetentionPolicy { //此注解类型的信

  • Java8新增的重复注解功能示例

    本文实例讲述了Java8新增的重复注解功能.分享给大家供大家参考,具体如下: 一 点睛 在Java 8以前,同一个程序元素前最多只能使用一个相同类型的Annotation:如果需要在同一个元素前使用多个相同类型的Annotation,则必须使用Annotation"容器". 为了将该注解改造成重复注解,需要使用@Repeatable修饰该注解,使用@Repeatable时必须为value成员变量指定值. 二 实战 1 定义重复注解 import java.lang.annotation

  • Java使用自定义注解实现函数测试功能示例

    本文实例讲述了Java使用自定义注解实现函数测试功能.分享给大家供大家参考,具体如下: 一 自定义注解 使用@interface定义Annotation 使用Annotation修饰程序中的类.方法.变量.接口等定义,通常我们会把Annotation放在所有修饰符之前. 定义带成员变量的Annotation. 为Annotation的成员变量指定初始值. 二 提取Annotation Annotation接口来代表程序元素前面的注释,该接口是所有Annotation类型的父接口. Annotat

  • java教程之java注解annotation使用方法

    1.概述 注解可以定义到方法上,类上,一个注解相当与一个类,就相当于实例了一个对象,加上了注解,就相当于加了一个标志. 常用的注解:@Override:表示重新父类的方法,这个也可以判断是否覆盖的父类方法,在方法前面加上此语句,如果提示的错误,那么你不是覆盖的父类的方法,要是提示的没有错误,那么就是覆盖的父类的方法.@SuppressWarnings("deprecation"):取消编译器的警告(例如你使用的方法过时了)@Deprecated:在方法的最上边也上此语句,表示此方法过时

随机推荐