成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Java 8默認方法會破壞你的(用戶的)代碼

開發(fā) 后端
Java 8的默認方法試圖嘗試更進一步簡化Java API。不幸的是,這一最近的語言擴展帶來了一系列復(fù)雜的規(guī)則,但只有少部分Java開發(fā)者意識到這一點。這篇文章告訴你為什么引入默認方法會破壞你的(用戶的)代碼。

Java 8的默認方法試圖嘗試更進一步簡化Java API。不幸的是,這一最近的語言擴展帶來了一系列復(fù)雜的規(guī)則,但只有少部分Java開發(fā)者意識到這一點。這篇文章告訴你為什么引入默認方法會破壞你的(用戶的)代碼。

[[137878]]

起初看來,默認方法給Java虛擬機的指令集帶來了很多新的特性。最終,開發(fā)庫的人能夠在不帶來客戶端代碼的兼容性問題的情況下,升級API。使用 默認方法,任何實現(xiàn)庫接口的類都自動適應(yīng)接口引入的默認方法。一旦用戶更新了他實現(xiàn)的類,就能夠很簡單使用更有意義的方法來覆蓋原有默認方法。更好的是, 用戶可以在覆蓋方法時候,調(diào)用接口的默認實現(xiàn),同時增加業(yè)務(wù)邏輯。

到現(xiàn)在為止,一切都是很好。但是,在創(chuàng)建接口的時候增加默認方法可能使得Java代碼不兼容。這個從下面的例子可以很容易弄明白。我們假設(shè)一個庫需要它的一個接口的作為輸入:

 

  1. interface SimpleInput { 
  2.   void foo(); 
  3.   void bar(); 
  4.  
  5. abstract class SimpleInputAdapter implements SimpleInput { 
  6.   @Override 
  7.   public void bar() { 
  8.     // some default behavior ... 
  9.   } 

Java 8之前,類似于上面聯(lián)合使用一個接口和一個適配器類的方式,是Java程序語言中一種非常常用的設(shè)計模式。該適配器通常由庫提供者提供,用于節(jié)省庫的使用者的某些操作。但是,如果采用接口的方式提供,就類似允許多重繼承了。

我們進一步假設(shè)一個用戶使用了如下的適配器:

  1. class MyInput extends SimpleInputAdapter { 
  2.   @Override 
  3.   public void foo() { 
  4.     // do something ... 
  5.   } 
  6.   @Override 
  7.   public void bar() { 
  8.     super.bar(); 
  9.     // do something additionally ... 
  10.   } 

通過這種實現(xiàn)方式,我們最終可以和庫進行交互。注意我們是怎樣覆蓋bar方法,并為默認的實現(xiàn)增加額外的功能的。

如果將該庫移植到Java 8,將會發(fā)生什么呢?首先,該庫很大可能性會廢棄適配器類,而使用默認方法提供該功能。最終,該接口的形式類似如下所示:

  1. interface SimpleInput { 
  2.   void foo(); 
  3.   default void bar() { 
  4.     // some default behavior 
  5.   } 

使用這個新的接口,用戶可以更新他的代碼,采用默認方法來代替原來的適配器類。通過使用接口代替適配器類的***的結(jié)果是,該類可以繼承 (extend)其它的類,而不是特定的適配器。現(xiàn)在我們進行實踐,移植MyInput類使其使用默認方法。因為我們現(xiàn)在能繼承其它類了,所以我們繼承一 個第三方的基礎(chǔ)類。我們這里不需要關(guān)心這個基礎(chǔ)類的作用,我們可以假設(shè)這個對我們的功能是有意義的。

  1. class MyInput extends ThirdPartyBaseClass implements SimpleInput { 
  2.   @Override 
  3.   public void foo() { 
  4.     // do something ... 
  5.   } 
  6.   @Override 
  7.   public void bar() { 
  8.     SimpleInput.super.bar(); 
  9.     // do something additionally ... 
  10.   } 

為了實現(xiàn)原始類相似的功能,我們使用Java 8的新的語法來調(diào)用指定接口的默認方法。同時,將我們方法中的一些邏輯移到基礎(chǔ)類中去。此時,你可能拍著我的肩膀說,這是一次非常好的重構(gòu)

我們相當(dāng)成功的使用了該庫。但是,維護人員需要增加另一個接口來提供更多的功能。該接口被 ComplexInput 接口所代替,這個接口繼承自 SimpleInput 接口,并增加了新的方法。因為默認方法通常來說是可以很安全的添加的,因此,維護人員覆蓋了 SimpleInput 的默認方法,提供了一個更好的默認方法。畢竟,這對于采用適配器類的方式來說是很平常的事情。

  1. interface ComplexInput extends SimpleInput { 
  2.   void qux(); 
  3.   @Override 
  4.   default void bar() { 
  5.     SimpleInput.super.bar(); 
  6.     // so complex, we need to do more ... 
  7.   } 

新的特性帶來了非常好的效果以至于維護 ThirdPartyBaseClass 的人也決定依賴該庫。為了完成這項工作,它在 ThirdPartyLibrary 中實現(xiàn)了 ComplexInput 接口。

但是這對 MyInput 類來說意味著什么呢?為了隱式的實現(xiàn) ComplexInput 接口,可繼承 ThirdPartyBaseClass 類,但是調(diào)用 SimpleInput 的默認方法突然變成非法的了。結(jié)果,用戶的代碼不能通過編譯。現(xiàn)在這種調(diào)用是被禁止的,因為Java認為這種在非直接子類中調(diào)用父類的父類的方法是非法 的。你只能在 ComplexInput 中去調(diào)用該默認方法,但是,這要求你顯示的在MyInput中實現(xiàn)該接口。對于庫的用戶來說,這種改變不是所預(yù)期的!

更奇怪的是,Java運行時卻不做這種限制。JVM的校驗器是允許一個編譯好的類去調(diào)用 SimpleInput::foo 方法的,即使該類是通過繼承更新后的 ThirdPartyBaseClass,從而隱式的實現(xiàn)了ComplexClass。這種限制只存在于編譯器中。

我們從這里能學(xué)到什么東西呢?簡單的說,確保不要在一個接口中覆蓋另一個接口的默認方法,既不要用默認方法覆蓋,也不要用抽象方法覆蓋。總的來說, 請謹(jǐn)慎使用默認方法。即使它使得Java的集合接口API輕易的發(fā)生了革命性的變化,但本質(zhì)上講,這種繼承層級之間的方法調(diào)用,增加系統(tǒng)的復(fù)雜性。而在 Java 7之前,你只需要沿著線性的類層級去查找真正調(diào)用的代碼。只有當(dāng)你覺得非常有必要的時候才去增加這種復(fù)雜性。

責(zé)任編輯:王雪燕 來源: ImportNew
相關(guān)推薦

2020-12-16 07:37:35

Java代碼成本

2014-04-10 18:00:10

Java8Java8教程

2014-03-28 11:08:16

Java 8多重繼承

2018-06-07 09:13:22

錯誤數(shù)據(jù)備份

2020-02-26 21:57:09

Lambdajava8方法引用

2010-10-29 10:33:55

ORACLE默認用戶

2010-06-10 14:14:18

個MySQL表索引

2018-12-14 15:51:47

Pandas數(shù)據(jù)數(shù)據(jù)結(jié)構(gòu)

2010-10-13 11:02:52

MySQL數(shù)據(jù)文件

2017-09-08 12:15:54

Python代碼Pythonic

2019-11-24 19:25:17

網(wǎng)絡(luò)安全邊緣計算攻擊

2023-07-27 10:24:54

數(shù)字化轉(zhuǎn)型NetOps

2021-03-04 08:14:37

Java8開發(fā)接口

2024-12-23 08:10:00

Python代碼性能代碼

2015-05-25 09:45:16

Java多繼承深入解析

2021-09-13 07:53:30

安全

2011-04-06 16:39:01

默認數(shù)據(jù)庫

2011-09-26 11:22:10

2013-11-18 09:18:40

代碼項目

2016-08-19 01:59:22

APPAPM用戶
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 日韩欧美一区二区三区在线播放 | 久久精品a | 欧美久久电影 | 天天射视频 | 国产精品国产亚洲精品看不卡15 | 精品成人免费一区二区在线播放 | 国产aa | 天天躁日日躁狠狠的躁天龙影院 | 国产一区二区在线播放 | 精品一区国产 | 欧美在线a | 国产午夜精品一区二区三区四区 | 国产综合在线视频 | 精品久久久久久久久久久久久久久久久 | 中文字幕亚洲区一区二 | 国产精品欧美一区二区三区不卡 | 日韩一区二区成人 | 欧美精品乱码久久久久久按摩 | 欧美高清视频一区 | 99pao成人国产永久免费视频 | 99久久精品免费看国产免费软件 | 99精品在线观看 | 视频一区二区在线 | 围产精品久久久久久久 | 久久精品国产一区二区三区 | 亚洲精品视频在线播放 | 美女黄色在线观看 | 久久久精品一区 | 国产高清精品一区二区三区 | 欧美日韩一区二区在线 | 毛片在线看片 | 超碰成人在线观看 | 伊人久久免费 | 天堂一区| 国产精品99免费视频 | 国产大毛片 | 日日夜夜av| 国产精品成人一区二区 | 国产精品日本一区二区在线播放 | 中文字幕在线一区二区三区 | 国产精品美女久久久久久免费 |