首页 > 代码库 > 《浅析:java不支持多继承的原因》

《浅析:java不支持多继承的原因》

  很久以前,博主的一个好朋友给我考了我一个问题,为什么Java不支持多继承,如果多继承会有什么错误。这个问题困扰了我很久,我从单继承方面去推导过,又从多态的层面去思考过,但都无法解释为什么Java不支持多继承的原因,后来也有在学校问老师,老师也只是让我多去思考,好吧,那我就多去思考吧。

  在1995年,Java语言的设计者James Gosling发表白皮书的时候谈到了一个想法:Java为什么不支持多继承。

       我们从设计人员给Java这门语言的定义去说起:JAVA:一个简单的,面向对象的,分布式的,解释型的,健壮的,安全的,体系结构中立的,可移植,高性能,多线程的,动态的语言。相比于其他的程序语言例如C++ 来说,Java省去了不少令人头疼的东西,比如说指针,多重继承。这的确给Java程序员带来了切身的感受:这门语言更加简单了。

      我们重新回归这个问题:Java为什么不支持多继承。现在我用图示来为大家进行解释:

  技术分享

  如上图所示,我们有两个类B和C继承自A.假设B和C都重写继承的方法,他们提供自己的实现。现在B和C从D继承多重继承。D应该继承,重写的方法,将用于重写的方法吗?它从B或C?在这里,我们有歧义。在C++中我们可能会掉入这个陷阱,但是它同样有自己的机制去解决这个问题,但是Java就不需要考虑这个问题,因为Java没有多重继承,所以菱形继承的问题问题永远不会困扰我们(或许当时Java设计者为了避免菱形继承的问题故意省去菱形继承处理机制也不一定)。

  从我们接触Java这门语言开始,这门语言就被与其他语言进行比较,多继承问题也被认为是Java与其他语言相比的短板之一,作为补充,Java增加了接口的多实现功能。或许我们的Java还将因为多继承的问题一直被质疑下去,但是省略了多继承真的是一个缺陷吗?或许这也是Java语言被更多人认可的优点之一呢!

 

《浅析:java不支持多继承的原因》