Java Annotation(Java 주석)의 실현 코드
                                            
 7945 단어  자바annotation
                    
다음은 제 가 만 든 demo 입 니 다.
프로젝트 구성:
 
 실행 효과:
 
 ====================================================
코드 부분:
주:많은 사람들 이 이 문 제 를 고려 할 것 입 니 다."이렇게 하 는 목적 은 무엇 입 니까?"이것 보다 편리 하지 않 은 프로필(xml,properties 등)을 만 들 수 있 습 니 다.
"우리 의 설정 정 보 를 프로그램 에 직접 기록 합 니 다...........................................................
하지만 annotation 과 xml,properties 등 프로필 의 장단 점 은 무엇 일 까요?
개인 적 인 관점:주석 을 쓸 때 편리 합 니 다.개발 의 효율 을 높 일 수 있 습 니 다.주석 프레임 워 크 에 유용 합 니 다.예 를 들 어 Hibernate,Struts,Spring 등 입 니 다.
원래 의 화제 로 돌아 가"이렇게 하 는 목적 은 무엇 입 니까?"---여 기 는 단지 demo 를 만들어 서 여러분 에 게 annotation 이 어떻게 된 일 인지 알려 드 리 는 것 입 니 다.
이 과정 에서 우리 가 정의 한 주석(Annotation)을 거의 사용 하지 않 습 니 다.만약 에 정말 사용 하면 이 블 로그 가 도움 이 될 것 입 니 다..^ ^
====================================================
/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;
     }
     
 }
/**
  * 
  */
 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();
         }
     }
 }
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Is Eclipse IDE dying?In 2014 the Eclipse IDE is the leading development environment for Java with a market share of approximately 65%. but ac...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.