源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2021-06-02 21:21 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Java Annotation(Java 注解)的实现代码
如果你想知道java annotation是什么?你可以先看看:“[url=http://www.infoq.com/articles/Annotation-Hammer]http://www.infoq.com/articles/Annotation-Hammer[/url]” 下面是我做的一个demo: 项目结构: [img]http://files.jb51.net/file_images/article/201305/2013050215523931.png[/img] 运行效果: [img]http://files.jb51.net/file_images/article/201305/2013050215523932.png[/img] ==================================================== 代码部分: 注:很多人会考虑这个问题,“这样做的目的是什么?我们可以做一个配置文件(xml,properties等),不是比这个跟方便...或者说 直接把我们的配置信息写入程序...这样也不会去解析我们写的注释..” 但是annotation和xml,properties等配置文件的优缺点是什么呢.. 个人观点:写注释的时候,比较方便...可以提高开发的效率.有用到注释的框架,如:Hibernate,Struts,Spring等 回到原话题,“这样做的目的是什么?“---这里只是做一个demo,让大家知道annotation是怎么一回事儿....在很多我们开发的 过程中,很少用到我们自己定义的注释(Annotation),如果真的用到了,那么这篇blog也许就有帮助了..^_^ ==================================================== /java_annotation/src/com/b510/hongten/annotation/JDBCAnnotation.java
[u]复制代码[/u] 代码如下:
/**   *   */  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
[u]复制代码[/u] 代码如下:
/**   *   */  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
[u]复制代码[/u] 代码如下:
/**   *   */  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();          }      }  }
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部