摘要:飛機(jī)就是一種交通工具,可飛行的能力是是飛機(jī)的屬性,通過繼承接口來獲取語言可沒有接口功能,但是它可以多重繼承。說是,因?yàn)閺恼Z法上看,的確是通過多重繼承實(shí)現(xiàn)的。所以從含義上理解,只是一個,不是一個。比如飛機(jī)照樣可以載客,就是不能飛了
REST API設(shè)計(jì)理念
民航飛機(jī)和直升機(jī)都是飛行器,又是交通工具,轎車也是交通工具,但是不會飛
可以多重繼承,但這違背了繼承必須是”is-a”關(guān)系
Java提供了接口interface功能,來實(shí)現(xiàn)多重繼承
public adstract class Vehicle { } public interface Flyable { public void fly(); } public class FlyableImpl implements Flyable { public void fly() { System.out.printIn("I am flying"); } } public class Airplane extends Vehicle implements Flyable { private flyable; public Airplane() { flyable = new FlyableImpl(); } public void fly() { flyable.fly(); } }
現(xiàn)在我們的飛機(jī)同時具有了交通工具及飛行器兩種屬性,而且我們不需要重寫飛行器中的飛行方法,同時我們沒有破壞單一繼承的原則。飛機(jī)就是一種交通工具,可飛行的能力是是飛機(jī)的屬性,通過繼承接口來獲取
Python語言可沒有接口功能,但是它可以多重繼承。那Python是不是就該用多重繼承來實(shí)現(xiàn)呢?是,也不是。說是,因?yàn)閺恼Z法上看,的確是通過多重繼承實(shí)現(xiàn)的。說不是,因?yàn)樗睦^承依然遵守”is-a”關(guān)系,從含義上看依然遵循單繼承的原則
class Vehicle(object): pass class PlaneMixin(object): def fly(self): print("I am flying") class Airplane(Vehicle, PlaneMixin) pass
可以看到,上面的Airplane類實(shí)現(xiàn)了多繼承,不過它繼承的第二個類我們起名為PlaneMixin,而不是Plane,這個并不影響功能,但是會告訴后來讀代碼的人,這個類是一個Mixin類。所以從含義上理解,Airplane只是一個Vehicle,不是一個Plane。這個Mixin,表示混入(mix-in),它告訴別人,這個類是作為功能添加到子類中,而不是作為父類,它的作用同Java中的接口。
使用Mixin類實(shí)現(xiàn)多重繼承要非常小心
首先它必須表示某一種功能,而不是某個物品,如同Java中的Runnable,Callable等
其次它必須責(zé)任單一,如果有多個功能,那就寫多個Mixin類
然后,它不依賴于子類的實(shí)現(xiàn)
最后,子類即便沒有繼承這個Mixin類,也照樣可以工作,就是缺少了某個功能。(比如飛機(jī)照樣可以載客,就是不能飛了^_^)
ReactJSvar PlaneMixin = function() { return { fly: function() { console.log("I am flying"); } } } var AirplaneComponent = React.createClass({ mixins: [PlaneMixin()], render: function() { return "what"s mixin
"; } })
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/45268.html
摘要:飛機(jī)就是一種交通工具,可飛行的能力是是飛機(jī)的屬性,通過繼承接口來獲取語言可沒有接口功能,但是它可以多重繼承。說是,因?yàn)閺恼Z法上看,的確是通過多重繼承實(shí)現(xiàn)的。所以從含義上理解,只是一個,不是一個。比如飛機(jī)照樣可以載客,就是不能飛了 REST API設(shè)計(jì)理念 showImg(https://segmentfault.com/img/remote/1460000019923606);sho...
摘要:看起來不錯再次,它現(xiàn)在仍然非常類似于基于功能的視圖。我們還需要重構(gòu)一下我們使用基于類的視圖。中文文檔目錄中文教程序列化中文教程請求和響應(yīng)中文教程基于類的視圖中文教程驗(yàn)證和權(quán)限中文教程關(guān)系和超鏈接中文教程中文教程模式和客戶端庫 我們也可以使用基于類的視圖編寫我們的API視圖,而不是基于函數(shù)的視圖。我們將看到這是一個強(qiáng)大的模式,允許我們重用常用功能,并幫助我們保持代碼DRY。 使用基于類的...
摘要:看起來不錯再次,它現(xiàn)在仍然非常類似于基于功能的視圖。我們還需要重構(gòu)一下我們使用基于類的視圖。中文文檔目錄中文教程序列化中文教程請求和響應(yīng)中文教程基于類的視圖中文教程驗(yàn)證和權(quán)限中文教程關(guān)系和超鏈接中文教程中文教程模式和客戶端庫 我們也可以使用基于類的視圖編寫我們的API視圖,而不是基于函數(shù)的視圖。我們將看到這是一個強(qiáng)大的模式,允許我們重用常用功能,并幫助我們保持代碼DRY。 使用基于類的...
摘要:看起來不錯再次,它現(xiàn)在仍然非常類似于基于功能的視圖。我們還需要重構(gòu)一下我們使用基于類的視圖。中文文檔目錄中文教程序列化中文教程請求和響應(yīng)中文教程基于類的視圖中文教程驗(yàn)證和權(quán)限中文教程關(guān)系和超鏈接中文教程中文教程模式和客戶端庫 我們也可以使用基于類的視圖編寫我們的API視圖,而不是基于函數(shù)的視圖。我們將看到這是一個強(qiáng)大的模式,允許我們重用常用功能,并幫助我們保持代碼DRY。 使用基于類的...
摘要:為什么要用對于序列化數(shù)據(jù)的解決方案已經(jīng)有以下幾種內(nèi)建序列化器它可以序列化但無法直接序列化單獨(dú)的數(shù)據(jù)。與對依舊有效默認(rèn)為用法轉(zhuǎn)換為字符串。 寫后臺的時候經(jīng)常需要寫數(shù)據(jù)接口,這時就需要用到序列化工具, 而默認(rèn)到序列化工具對 Django model 的序列化支持有限。 同時 Django 本身的序列化工具我在使用時也覺得有諸多不便,因此我嘗試自己寫了一個快速序列化工具,幫助我快速簡單的實(shí)現(xiàn)...
閱讀 1784·2023-04-25 21:50
閱讀 2429·2019-08-30 15:53
閱讀 774·2019-08-30 13:19
閱讀 2752·2019-08-28 17:58
閱讀 2476·2019-08-23 16:21
閱讀 2709·2019-08-23 14:08
閱讀 1384·2019-08-23 11:32
閱讀 1448·2019-08-22 16:09