实例讲授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,而不督工场类如何变革。这就是接口的意义—-抽象。