`

Java语言接口与继承的本质

    博客分类:
  • Java
阅读更多

大多数人认为,接口的意义在于顶替多重继承。众所周知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()
  {
    //关闭数据库
  }
  }

  类似的当然还有Oracle.java等等,接口DB给这些类归了个类,在应用程序中我们这样定义对象:

  org.bromon.test.DB myDB;

  使用myDB来操作数据库,就可以不用管实际上我所使用的是哪个类,这就是所谓的“开-闭”原则。但是问题在于接口是不能实例化的,myDB=new DB(),这样的代码是绝对错误的,我们只能myDB=new Mysql()或者myDB=new Oracle()。麻烦了,我还是需要指定具体实例化的是哪个类,用了接口跟没用一样。所以我们需要一个工厂:

  package org.bromon.test;
  public class DBFactory
  {
  public static DB Connection getConn()
  {
    Return(new Mysql());
  }
  }

  所以实例化的代码变成:myDB=DBFactory.getConn();

  这就是23种模式中最基础的普通工厂(Factory),工厂类负责具体实例化哪个类,而其他的程序逻辑都是针对DB这个接口进行操作,这就是“针对接口编程”。责任都被推卸给工厂类了,当然你也可以继续定义工厂接口,继续把责任上抛,这就演变成抽象工厂(Abstract Factory)。

  整个过程中接口不负责任何具体操作,其他的程序要连接数据库的话,只需要构造一个DB对象就OK,而不管工厂类如何变化。这就是接口的意义----抽象。

  继承的概念不用多说,很好理解。为什么要继承呢?因为你想重用代码?这绝对不是理由,继承的意义也在于抽象,而不是代码重用。如果对象A有一个run()方法,对象B也想有这个方法,所以有人就Class B extends A。这是不经大脑的做法。如果在B中实例化一个A,调用A的Run()方法,是不是可以达到同样的目的?如下:

  Class B
  {
  A a=new A();
  a.run();
  }

  这就是利用类的聚合来重用代码,是委派模式的雏形,是GoF一贯倡导的做法。

  那么继承的意义何在?其实这是历史原因造成的,最开始的OO语言只有继承,没有接口,所以只能以继承来实现抽象,请一定注意,继承的本意在于抽象,而非代码重用(虽然继承也有这个作用),这是很多Java烂书最严重的错误之一,它们所造成的阴影,我至今还没有完全摆脱,坏书害人啊,尤其是入门类的,流毒太大。什么时候应该使用继承?只在抽象类中使用,其他情况下尽量不使用。抽象类也是不能实例化的,它仅仅提供一个模版而已,这就很能说明问题。

  软件开发的万恶之源,一是重复代码而不是重用代码,二是烂用继承,尤以c++程序员为甚。Java中取缔多重继承,目的就是制止烂用继承,实是非常明智的做法,不过很多人都不理解。Java能够更好的体现设计,这是让我入迷的原因之一。

 

 

 

 

 

分享到:
评论

相关推荐

    2022年Java语言接口与继承的本质Java教程.docx

    在Java编程语言中,接口(Interface)和继承(Inheritance)是面向对象设计的重要概念,它们在2022年的Java教程中占据了重要的地位。在Java中,接口主要用于定义类的行为规范,而继承则用于实现类之间的层次结构,这...

    java语言要点总结

    ### Java语言要点总结 #### 一、Java中的对象操纵与引用 Java作为一种面向对象的编程语言,其核心特性之一就是对象的操纵与管理。在Java中,一切都是对象,包括基本数据类型也被包装成了对象的形式。Java通过引用...

    Java语言基础入门教程 Java实训教程 7.接口 共25页.pptx

    ### Java语言基础入门教程——接口篇 #### 一、引言 在《Java语言基础入门教程 Java实训教程 7.接口 共25页.pptx》这份资料中,主要介绍了Java中的接口概念及其使用方法。接口作为一种重要的设计模式,在实际开发...

    Java抽象类接口与多态PPT教案学习.pptx

    Java抽象类接口与多态是Java编程语言的核心概念,本篇资源文件将详细介绍Java中的抽象类、接口和多态的概念、特点和应用。 一、抽象类 抽象类是Java中的一种特殊的类,它不能被实例化,仅供子类继承使用。抽象类的...

    Java语言程序设计-基础篇(原书第8版).pdf

    《Java语言程序设计-基础篇(原书第8版)》这本书作为Java编程语言学习的经典教材,涵盖了Java编程的基础知识点,适合初学者入门和提高。由于给出的文件内容只是有关版权声明、标签以及一个重复的网址,并无实质性的...

    4747《Java语言程序设计(一)》2009年1月至2010年10月试题和答案

    Java语言程序设计是计算机科学与技术专业中一门重要的基础课程,尤其对于初学者而言,它提供了进入编程世界的入口。这份名为“4747《Java语言程序设计(一)》2009年1月至2010年10月试题和答案”的资源集合,包含了两...

    Java语言入门级的十二大特色详细介绍

    Java语言的十二大特色详细介绍,为我们提供了一个深入了解Java编程语言本质的机会。以下是对这十二大特色更为详尽的解析: 1. **Java是简单的** Java语言在设计上尽可能地简化了C++中复杂的特性,如去除了运算符...

    面向对象抽象思维与java继承机制

    - **接口继承**:Java通过接口支持多继承的功能。一个类可以实现多个接口,每个接口定义了一组方法签名,实现这些接口的类必须提供这些方法的具体实现。 - **多态**:继承机制还支持多态性,即子类对象可以被视为...

    JAVA入门-接口-语法

    #### Java语言接口与继承的本质及语法详解 在Java编程语言中,接口(Interface)和继承(Inheritance)是面向对象编程的重要组成部分,它们各自承担着不同的职责,并为程序设计提供了灵活性和扩展性。本文将详细...

    C++造的坑Java来补,补坑的路上Java接口怎么写.pdf

    通过这些知识点的梳理,我们可以看到Java接口设计背后的逻辑和Java语言在发展过程中针对不同问题的解决策略,以及如何在保持语言一致性的同时不断增强其表达能力和灵活性。这些知识点对于理解Java编程思想和接口的...

    Java语言程序设计 第8版 Y.Daniel Lang 编程练习题+课后复习题+例题程序

    该教材不仅详细介绍了Java语言的基本语法、类与对象的使用、继承和多态性等核心概念,还系统地讲解了接口的定义和使用、异常处理机制、集合框架以及输入/输出流处理等高级主题。除此之外,教材还涵盖了线程的创建与...

    浅析高职教学之Java抽象类与接口.pdf

    * Java语言只支持单继承,而接口可以实现多重继承结构。 3. 二者的关系与主要区别 接口和抽象类都不能被实例化,它们都位于继承树的顶端,用于被其他的类实现和继承:二者都可以包含抽象方法,实现接口或是继承...

    《Java语言程序设计》期末复习题

    ### Java语言程序设计知识点解析 #### 一、判断题知识点解析 1. **Java程序里,创建新的类对象使用关键字new,回收无用的类对象使用关键字free。** - **解析**: 在Java中,创建新对象确实使用`new`关键字。然而,...

    Java中抽象类和接口的区别与作用详解

    ### Java中抽象类和接口的区别与作用详解 #### 一、引言 在Java编程语言中,`abstract class`和`interface`是两种用于定义抽象类的重要机制。这两种机制不仅支持了Java的强大面向对象特性,而且也在实际开发过程中...

    Java中抽象类与接口的比较.pdf

    Java 中抽象类与接口的比较 Java 语言中,抽象类(abstract class)和接口(interface)是两种支持抽象类定义的机制。抽象类和接口之间存在着许多相似性,但是也存在本质的区别。 一、 抽象类 在 Java 程序设计中...

    Java语言程序设计(基础篇)原书第六版课后习题

    《Java语言程序设计(基础篇)》第六版的课后习题解答涵盖了Java编程的基础概念、语法和应用,是学习者巩固理论知识、提升实践能力的重要资料。此资源主要针对那些希望通过解决实际问题来深入理解Java编程的自学者。...

    Java 语言基础 —— 非常符合中国人习惯的Java基础教程手册

    在 java 语言中,Java 程序的基本单位是类,也就是说:一个 Java 程序是由多个类组成 的。定义一个类与定义一个数据类型是有区别的。在程序设计语言中,把定义数据类型的能 力作为一种很重要的能力来对待。在面向...

    JAVA语言教学案例

    ### JAVA语言教学案例:面向对象与面向过程 #### 面向对象与面向过程的概念及其对比 面向对象和面向过程是编程领域中的两种基本方法论,它们分别代表着不同的思考问题和解决问题的方式。这两种方法各有优势,适用...

    Java中抽象类和接口的区别与联系.pdf

    "Java中抽象类和接口的区别与联系" Java中抽象类和接口是面向对象程序设计语言中两种不同的机制,都是支持类定义的方式。抽象类和接口之间在对于抽象类定义的支持方面具有很大的相似性,但它们之间还是有很大的区别...

Global site tag (gtag.js) - Google Analytics