Java Annotation(Java 注解)的实现代码

时间:2023-01-09 00:36:17 

如果你想知道java annotation是什么?你可以先看看:“http://www.infoq.com/articles/Annotation-Hammer”

下面是我做的一个demo:

项目结构:

Java Annotation(Java 注解)的实现代码

运行效果:

Java Annotation(Java 注解)的实现代码

====================================================

代码部分:

注:很多人会考虑这个问题,“这样做的目的是什么?我们可以做一个配置文件(xml,properties等),不是比这个跟方便...或者说

直接把我们的配置信息写入程序...这样也不会去解析我们写的注释..”

但是annotation和xml,properties等配置文件的优缺点是什么呢..

个人观点:写注释的时候,比较方便...可以提高开发的效率.有用到注释的框架,如:Hibernate,Struts,Spring等

回到原话题,“这样做的目的是什么?“---这里只是做一个demo,让大家知道annotation是怎么一回事儿....在很多我们开发的

过程中,很少用到我们自己定义的注释(Annotation),如果真的用到了,那么这篇blog也许就有帮助了..^_^

====================================================

/java_annotation/src/com/b510/hongten/annotation/JDBCAnnotation.java


/**
  *
  */
 package com.b510.hongten.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;

 /**
  * JDBC annotation
  *
  * @author Hongten
  * @date 2013-4-10
  */
 @Documented
 @Retention(RetentionPolicy.RUNTIME)
 @Target(ElementType.TYPE)
 public @interface JDBCAnnotation {

     String driver() default "com.mysql.jdbc.Driver";

     String dbName() default "";

     String encoding() default "UTF-8";

     String port() default "3306";

     String host() default "localhost";

     String userName() default "root";

     String password() default "";

 }


/java_annotation/src/com/b510/hongten/jdbc/JDBCUtil.java


/**
  *
  */
 package com.b510.hongten.jdbc;

 import com.b510.hongten.annotation.JDBCAnnotation;

 /**
  * @author Hongten
  * @date 2013-4-12
  */
 @JDBCAnnotation(dbName = "db_lucene", port = "3306", host = "192.168.0.119", userName = "root", password = "root")
 public class JDBCUtil {

     private static String driver;
     private static String dbName;
     private static String encoding;
     private static String port;
     private static String host;
     private static String passwrod;
     private static String userName;
     private static String url;

     public void checkInterceptor(Class<?> cl) throws Exception {
         boolean flag = cl.isAnnotationPresent(JDBCAnnotation.class);
         if (flag) {
             JDBCAnnotation jdbcAnnotation = cl.getAnnotation(JDBCAnnotation.class);
             driver = jdbcAnnotation.driver();
             dbName = jdbcAnnotation.dbName();
             encoding = jdbcAnnotation.encoding();
             port = jdbcAnnotation.port();
             host = jdbcAnnotation.host();
             userName = jdbcAnnotation.userName();
             passwrod = jdbcAnnotation.password();
             url = "jdbc:mysql://" + host + ":" + port + "/" + dbName + "?characterEncoding=" + encoding;
             System.out.println("JDBCUtil加载注释完成...");
         }
     }

     public JDBCUtil() {
         try {
             checkInterceptor(JDBCUtil.class);
         } catch (Exception e) {
             e.printStackTrace();
         }
     }

     public static String getDriver() {
         return driver;
     }

     public static void setDriver(String driver) {
         JDBCUtil.driver = driver;
     }

     public static String getDbName() {
         return dbName;
     }

     public static void setDbName(String dbName) {
         JDBCUtil.dbName = dbName;
     }

     public static String getEncoding() {
         return encoding;
     }

     public static void setEncoding(String encoding) {
         JDBCUtil.encoding = encoding;
     }

     public static String getPort() {
         return port;
     }

     public static void setPort(String port) {
         JDBCUtil.port = port;
     }

     public static String getHost() {
         return host;
     }

     public static void setHost(String host) {
         JDBCUtil.host = host;
     }

     public static String getPasswrod() {
         return passwrod;
     }

     public static void setPasswrod(String passwrod) {
         JDBCUtil.passwrod = passwrod;
     }

     public static String getUserName() {
         return userName;
     }

     public static void setUserName(String userName) {
         JDBCUtil.userName = userName;
     }

     public static String getUrl() {
         return url;
     }

     public static void setUrl(String url) {
         JDBCUtil.url = url;
     }

    
 }


/java_annotation/src/com/b510/hongten/jdbc/JDBCTest.java


/**
  *
  */
 package com.b510.hongten.jdbc;

 import java.sql.Connection;
 import java.sql.DriverManager;
 import java.sql.PreparedStatement;
 import java.sql.ResultSet;
 import java.sql.SQLException;

 /**
  *
  * @author Hongten</br>
  * @date 2012-7-16
  *
  */
 public class JDBCTest {
     @SuppressWarnings("static-access")
     public static void main(String[] args) {
         JDBCUtil jdbcUtil = new JDBCUtil();
         String sql = "select * from mymails";
         try {
             Class.forName(jdbcUtil.getDriver());
             Connection conn = DriverManager.getConnection(jdbcUtil.getUrl(), jdbcUtil.getUserName(), jdbcUtil.getPasswrod());
             PreparedStatement ps = conn.prepareStatement(sql);
             ResultSet rs = ps.executeQuery();
             while (rs.next()) {
                 System.out.println("id : " + rs.getInt(1) + " name : " + rs.getString(2) + " mail : " + rs.getString(3));
             }
             // 关闭记录集
             if (rs != null) {
                 try {
                     rs.close();
                 } catch (SQLException e) {
                     e.printStackTrace();
                 }
             }

             // 关闭声明
             if (ps != null) {
                 try {
                     ps.close();
                 } catch (SQLException e) {
                     e.printStackTrace();
                 }
             }

             // 关闭链接对象
             if (conn != null) {
                 try {
                     conn.close();
                 } catch (SQLException e) {
                     e.printStackTrace();
                 }
             }
         } catch (Exception e) {
             e.printStackTrace();
         }
     }

 }


标签:java,annotation
0
投稿

猜你喜欢

  • C#实现验证码功能

    2021-11-28 22:20:27
  • Android布局技巧之合并布局

    2021-10-27 11:12:57
  • Java实现简单的递归操作方法实例

    2021-11-01 14:37:32
  • 使用java采集京东商城行政区划数据示例

    2023-04-17 06:31:52
  • Apache和Tomcat有什么区别_动力节点Java学院整理

    2023-08-15 08:49:44
  • 利用Java写一个学生管理系统

    2023-09-24 17:06:54
  • Java中JMM与volatile关键字的学习

    2022-03-24 00:12:00
  • Java调用Shell命令的方法

    2022-01-06 20:01:34
  • Java Maven高级之插件开发详解

    2023-05-11 19:10:02
  • Java多种方式实现生产者消费者模式

    2023-12-13 05:56:16
  • C#中datagridview使用tooltip控件显示单元格内容的方法

    2022-04-15 12:23:23
  • c++虚函数与虚函数表原理

    2023-12-09 07:22:45
  • Java 中的 xx ≠ null 是什么新语法

    2022-09-10 20:51:13
  • 在当前Activity之上创建悬浮view之WindowManager悬浮窗效果

    2023-02-09 21:02:12
  • Android TextView字体颜色设置方法小结

    2023-02-22 14:44:52
  • Android adb命令中pm工具的作用及用法说明

    2022-05-27 23:38:42
  • 在eclipse中中文汉字乱码的解决方案

    2023-11-25 10:13:27
  • Android 通过TCP协议上传指定目录文件的方法

    2023-11-07 23:34:11
  • C#中char和string的入门使用教程

    2022-06-14 15:07:17
  • java中将一个List等分成n个list的工具方法(推荐)

    2022-04-12 09:25:09
  • asp之家 软件编程 m.aspxhome.com