程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> 澄清Java——接口與繼承

澄清Java——接口與繼承

編輯:關於JAVA

計算機學院研二的兄弟與我討論Java,一見面,幾個問題全是關於接口,接口有什麼用?為什麼要用接口?什麼時候該使用接口?很慶幸他們不是問我Java如何連接SQL Server,或者是如何開發J2EE應用,這類問題有殺傷力,避之則吉。今年計算機學院本科有個畢業設計課題是做J2ME,選這個題目的學生在5月末都還在苦著臉研究Java.util.*這個包,這個這個……唉。

大多數人認為,接口的意義在於頂替多重繼承。眾所周知Java沒有c++那樣多重繼承的機制,但是卻能夠實作多個接口。其實這樣做是很牽強的,接口和繼承是完全不同的東西,接口沒有能力代替多重繼承,也沒有這個義務。接口的作用,一言以蔽之,就是標志類的類別(type of class)。把不同類型的類歸於不同的接口,可以更好的管理他們。OO的精髓,我以為,是對對象的抽象,最能體現這一點的就是接口。為什麼我們討論設計模式都只針對具備了抽象能力的語言(比如c++、Java、c#等),就是因為設計模式所研究的,實際上就是如何合理的去抽象。(cowboy的名言是“抽象就是抽去像的部分”,看似調侃,實乃至理)。

設計模式中最基礎的是工廠模式(Factory),在我最近的一個很簡單的應用中,我想盡量的讓我的程序能夠在多個數據庫間移植,當然,這涉及很多問題,單是如何兼容不同DBMS的SQL就讓人頭痛。我們不妨先把問題簡單化,只考慮如何連接不同的數據庫。

假設我有很多個類,分別是MySQL.java、SQLServer.java、Oracle.java、DB2.Java,他們分別連接不同的數據庫,統一返回一個Connection對象,並且都有一個close方法,用於關閉連接。只需要針對你的DBMS,選擇不同的類,就可以用了,但是我的用戶他會使用什麼數據庫?我不知道,我希望的是盡量少的修改代碼,就能滿足他的需要。我可以抽象如下接口:

package org.bromon.test;

public interface DB

{

  Java.sql.Connection openDB(String url,String user,String passWord);

  void close();

}

這個接口只定義兩個方法,沒有任何有實際意義的代碼,具體的代碼由實作這個接口的類來給出,比如MySQL.Java:

Package org.bromon.test;

import Java.sql.*;

public class MySQL implements DB

{

  private String url=”jdbc:MySQL:localhost:3306/test”;

  private String user=”root”;

  private String passWord=””;

  private Connection conn;

  public Connection openDB(url,user,passWord)

  {

    //連接數據庫的代碼

  }

public void close()

  {

    //關閉數據庫

  }

}

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved