您好,登錄后才能下訂單哦!
這篇文章主要介紹“Java中的接口怎么實現”,在日常操作中,相信很多人在Java中的接口怎么實現問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Java中的接口怎么實現”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
接口的作用
接口的作用簡單一點就是:接口是用來標記類的,不同的類屬于不同的接口(通過向上轉型),管理接口比管理各種各樣的類方便多了,接口體現了抽象的觀點,什么是抽象?抽象就是"抽去像的部分"。
使用接口解決問題
問題:現在我們要寫個連接數據庫的類給用戶使用,有兩個函數:一個返回Connection對象,另一個是關閉數據庫,close(),一般的解決方法是:給每個數據庫寫一個類,再根據用戶使用的數據庫決定使用具體的類。
好的,我們看看這樣有什么不好之處:
(1).首先每個類都要有重復的代碼,造成代碼的膨脹;
(2).其次最重要的是我們并不知道用戶使用什么數據庫,可能是Oracle,可能是mysql,也可能是sqlserver等,這個問題很難解決。
解決方案:
首先我們定義接口:
public interface DataBase
{
java.sql.Connection openDB(String url,String user,String password);
void close();
}
我們定義了兩個方法,openDB返回Connection對象,close()關閉數據庫;
具體的實現在實現DataBase接口的類中;
下面看看實現:
import java.sql.*;
public class Mysql implements DataBase
{
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()
{
//關閉數據庫
}
}
類mysql實現了DataBase接口,下面還有實現了DataBase接口的oraclesql等類;
這些類都歸于DataBase接口了,如何在應用程序中使用呢?
我們要定義DataBase對象 myDB,通過myDB來操縱數據庫,可以不要分清是哪個類了。
另外的問題:Java中不許我們實例化接口,如DataBase myDB=new DataBase();
我們只能myDB=new Mysql()或者myDB=new Oracle()。這樣我們還必須指定實例化哪個對象,好像前面的努力都白費了啊!!那怎么辦呢,我們需要一個工廠:
public class DBFactory
{
public static DataBase Connection getConn()
{
Return(new Mysql());
}
}
實例化的代碼變成:myDB=DBFactory.getConn();
整個過程中接口不負責任何具體操作,其他的程序要連接數據庫的話,只需要構造一個DB對象就OK,而不管工廠類如何變化。這就是接口的意義----抽象。
到此,關于“Java中的接口怎么實現”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。