当前位置:七道奇文章资讯编程技术Java编程
日期:2011-03-22 16:15:00  来源:本站整理

实例讲授Java中的接口的作用[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中的接口的作用[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • 实例讲授操纵JDOM对XML文件举行操作
  • 实例讲授Java中的接口的作用
  • 实例讲授Servlet的图象处理
  • <b>实例讲授Tomcat下绑定JMS操纵服务器</b>
  • 实例讲授Oracle里抽取随机数的多种办法
  • <b>Oracle数据库链接成立本领与实例讲授-开辟技术</b>
  • 实例讲授Oracle 9i数据坏块的处理-性能调优
  • 操纵实例讲授MySQL数据库做到查询最优化
  • Linux at号令编辑和配置实例讲授
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .