亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

Java Annotation(Java 注解)的實現代碼

2019-11-26 16:09:27
字體:
來源:轉載
供稿:網友

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

下面是我做的一個demo:

項目結構:

運行效果:

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

代碼部分:

注:很多人會考慮這個問題,“這樣做的目的是什么?我們可以做一個配置文件(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();
         }
     }

 }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97在线看福利| 97国产suv精品一区二区62| 97视频色精品| 亚洲视频专区在线| 青青草精品毛片| 俺去亚洲欧洲欧美日韩| 亚洲视频网站在线观看| 欧美成人全部免费| 成人福利视频在线观看| 国产九九精品视频| 日韩av最新在线观看| 亚洲欧美国产精品va在线观看| 亚洲欧美制服中文字幕| 亚洲一区二区久久久久久| 国产成人精品国内自产拍免费看| 777午夜精品福利在线观看| 欧美日韩成人在线播放| 91精品久久久久| 亚洲国产一区二区三区在线观看| 色综合影院在线| 欧美成年人网站| 日韩精品视频三区| 97超碰国产精品女人人人爽| 国内精品美女av在线播放| 中文字幕日韩欧美精品在线观看| 色综合老司机第九色激情| 国产精品高清在线| 欧美成人午夜视频| 精品中文字幕久久久久久| 91麻豆国产语对白在线观看| 69国产精品成人在线播放| 97人人爽人人喊人人模波多| 亚洲精品一区久久久久久| 国产在线精品成人一区二区三区| 欧美午夜激情小视频| 国产精品日韩久久久久| 91亚洲精品视频| 亚洲成年人影院在线| 在线中文字幕日韩| 大荫蒂欧美视频另类xxxx| 欧美精品videofree1080p| 日本在线精品视频| 欧美丰满老妇厨房牲生活| 一本色道久久88综合亚洲精品ⅰ| 久久成人av网站| 国产一区二区三区视频免费| 久久久国产在线视频| 亚洲精品动漫100p| 中文日韩电影网站| 久久精品亚洲一区| 欧美大学生性色视频| 欧美性xxxxx| 欧美资源在线观看| 欧美性xxxxxxxxx| 午夜剧场成人观在线视频免费观看| 美日韩丰满少妇在线观看| 日韩电视剧在线观看免费网站| 国产精品v日韩精品| 亚洲va久久久噜噜噜| 韩国三级日本三级少妇99| 精品中文字幕久久久久久| 国产一区二区三区网站| 久久这里只有精品99| 欧美性xxxxx极品娇小| 国产欧美中文字幕| 亚洲系列中文字幕| 亚洲欧美日本另类| 国产成人免费av| 欧美日韩国产成人在线观看| 国产免费亚洲高清| 日韩免费高清在线观看| 亚洲欧美国产制服动漫| 欧美多人爱爱视频网站| 久久伊人91精品综合网站| 成人免费网站在线| 中文欧美日本在线资源| 亚洲国产精品免费| 亚洲男人av电影| 欧美精品成人91久久久久久久| 亚洲成色777777女色窝| 亚洲情综合五月天| 美女撒尿一区二区三区| 不卡中文字幕av| 国产91免费观看| 91精品国产综合久久香蕉的用户体验| 亚洲最新在线视频| 深夜福利国产精品| 日韩美女视频免费在线观看| 欧洲成人午夜免费大片| 中文字幕亚洲综合久久筱田步美| 欧美国产日韩xxxxx| 68精品国产免费久久久久久婷婷| 丝袜美腿亚洲一区二区| 国产亚洲欧美日韩美女| 亚洲天堂网站在线观看视频| 日韩高清中文字幕| 久久久国产视频| 日韩精品中文在线观看| 欧美色视频日本高清在线观看| 亚洲成人三级在线| 欧美电影免费观看高清完整| 亚洲伊人久久大香线蕉av| 欧美资源在线观看| 久久这里只有精品视频首页| 国产视频精品va久久久久久| 97av在线视频免费播放| 国产成人精品一区二区在线| 日韩亚洲第一页| 国产日韩精品一区二区| 国产精品wwww| 国外成人在线播放| 成人久久精品视频| 91久久久久久久久久久| 91九色综合久久| 亚洲欧美自拍一区| 国产一区二区三区毛片| 一本一道久久a久久精品逆3p| 国产美女精彩久久| 国产精品日韩电影| 亚洲欧美日韩中文视频| 日韩精品视频在线观看免费| 国产精品精品视频一区二区三区| 日韩av免费在线播放| 久久九九亚洲综合| 国产精品主播视频| 夜色77av精品影院| 久久久久久网站| 色综合导航网站| 国产精品一区电影| 成人激情视频网| 欧美激情网站在线观看| 欧美一级电影免费在线观看| 亚洲第一精品夜夜躁人人爽| 亚洲国产精品久久| 欧美精品福利视频| 国产日韩欧美在线| 91最新在线免费观看| 日韩精品视频中文在线观看| 欧美日韩不卡合集视频| 成人免费直播live| 欧美中文在线观看国产| 亚洲第一中文字幕在线观看| 成人国产精品一区二区| 久久久综合免费视频| 国产69精品99久久久久久宅男| 久久精品99久久香蕉国产色戒| 中文字幕亚洲自拍| 91成人免费观看网站| 欧美二区在线播放| 亚洲性av在线| 国产精品激情av电影在线观看| 日本在线精品视频| 欧美日韩在线第一页| 日韩精品在线观| 欧美亚洲国产成人精品| 久久精品视频在线| 日韩在线视频观看正片免费网站| 91亚洲人电影| 国产精品福利网| 日韩精品中文字幕在线| 一区二区三区无码高清视频| 欧美电影在线观看| 亚洲乱亚洲乱妇无码| 亚洲最大福利网站|