0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

面向?qū)ο缶幊虝粧仐墕??這5大問題不容忽視

電子設(shè)計 ? 來源:電子設(shè)計 ? 作者:電子設(shè)計 ? 2020-10-30 12:03 ? 次閱讀

20 世紀(jì) 60 年代,編程遇到了一個大問題:計算機還沒有那么強大,需要以某種方式平衡數(shù)據(jù)結(jié)構(gòu)和程序之間的能力。

這意味著,如果你有大量數(shù)據(jù),那么不將計算機推向極限就無法充分利用這些數(shù)據(jù)。另外,如果你需要做很多事情,那么你就不能使用過多的數(shù)據(jù),否則計算機將會一直運行下去。

接下來到了 1966、1967 年,Alan Kay 從理論上證明可以使用封裝的微型計算機。這些微型計算機不共享數(shù)據(jù),而是通過消息傳遞進(jìn)行通信。這樣就可以更加經(jīng)濟地使用計算資源。

盡管這個想法很巧妙,但直到 1981 年,面向?qū)ο缶幊滩懦蔀橹髁鳌T谀侵?,它就沒有停止過吸引新的和經(jīng)驗豐富的軟件開發(fā)者。面向?qū)ο蟮?a target="_blank">程序員市場一如既往地忙碌。

但是在最近幾年中,這種已有幾十年歷史的編程范式受到越來越多的批評。難道是在面向?qū)ο缶幊檀笮衅涞?40 年之后,技術(shù)已經(jīng)超越了這種范式?

函數(shù)和數(shù)據(jù)耦合

面向?qū)ο缶幊痰闹饕枷敕浅:唵危簢L試將一個功能強大的程序整體分解為功能同樣強大的多個部分。這樣就可以將一些數(shù)據(jù)和那些只在相關(guān)數(shù)據(jù)上使用的函數(shù)耦合起來。

注意,這僅涵蓋封裝的概念。也就是說,位于對象內(nèi)部的數(shù)據(jù)和函數(shù)對于外部是不可見的。我們只能通過消息(通常通過 getter 和 setter 函數(shù))與對象的內(nèi)容進(jìn)行交互。

繼承性和多態(tài)性并沒有包含在最初的設(shè)計想法中,但是對于現(xiàn)在的面向?qū)ο缶幊潭允潜匦璧?。繼承基本上意味著開發(fā)者可以定義具有其父類所有屬性的子類。直到 1976 年,即面向?qū)ο蟮某绦蛟O(shè)計的概念問世十年之后,繼承性才被引入。

又過了十年,多態(tài)性才進(jìn)入面向?qū)ο蟮木幊?。簡單來講,這意味著某種方法或?qū)ο罂梢杂米銎渌椒ɑ驅(qū)ο蟮哪0?。從某種意義上說,多態(tài)性是繼承性的泛化,因為并不是原始方法或?qū)ο蟮乃袑傩远夹枰獋鬏數(shù)叫聦嶓w。相反,你還可以選擇重寫一些屬性。

多態(tài)性的特殊之處在于,即使兩個實體在源代碼中互相依賴,被調(diào)用實體的工作方式也更像插件。這使得開發(fā)人員的工作變得輕松,因為他們不必?fù)?dān)心運行時的依賴關(guān)系。

值得一提的是,繼承性和多態(tài)性并不是面向?qū)ο缶幊趟赜械?。真正的區(qū)別在于封裝數(shù)據(jù)及其包含的方法。在計算資源比今天稀缺得多的時代,這是一個天才的想法。


面向?qū)ο缶幊讨械?5 大問題

面向?qū)ο蟮木幊桃唤?jīng)問世,便改變了開發(fā)人員看待代碼的方式。20 世紀(jì) 80 年代以前,過程式編程非常面向機器。開發(fā)人員需要非常了解計算機的工作原理才能編寫好的代碼。

通過封裝數(shù)據(jù)和其他方法,面向?qū)ο蟮木幊淌管浖_發(fā)更加以人為中心,符合人類的直覺。比如,方法 drive() 屬于 car 數(shù)據(jù)組,而不是 teddybear 組。之后出現(xiàn)的繼承性也很直觀。比如,現(xiàn)代汽車(Hyundai)是汽車的一個子類,并且具有相同的屬性,但 PooTheBear 不是,這樣很好理解。

香蕉猴子叢林問題

想象一下,你正在設(shè)置一個新程序,并且正在考慮設(shè)計一個新類。然后,你回想起為另一個項目創(chuàng)建的簡潔的小類,發(fā)現(xiàn)其對正在進(jìn)行的工作很合適。

沒問題,你可以將以前項目中的類在新項目中復(fù)用。

這里有一個問題:這個類可能是另一個類的子類,因此你需要將它的父類也包含在內(nèi)。然后你會發(fā)現(xiàn),這個父類可能也是另一個類的子類,以此類推,最后要面對一堆代碼。

Erlang 的創(chuàng)建者 Joe Armstrong 曾有一句名言:「面向?qū)ο笳Z言的問題在于,它們自帶其自身周圍的所有隱式環(huán)境。你想要香蕉,但是得到的卻是拿著香蕉的大猩猩和整個叢林?!?/p>

這幾乎可以說明一切。復(fù)用類是可以的,實際上這可能是面向?qū)ο缶幊痰闹饕獌?yōu)點,但不要將其發(fā)揮到極致。有時你應(yīng)該建立一個新的類,而不是添加大量依賴項。


脆弱的基類問題

想象一下,如果你已經(jīng)成功地將另一個項目中的類復(fù)用于新的代碼,那么如果基類發(fā)生變化會怎樣?

這可能會破壞你整個新項目的代碼,即使你可能什么也沒做。一旦有人更改了基類中的一個細(xì)節(jié),而這一點又對你的項目至關(guān)重要,那么這種影響將是非常大并且突然的。

使用繼承的次數(shù)越多,潛在的維護(hù)工作就越多。因此,即使在短期內(nèi)復(fù)用代碼非常有效,但從長遠(yuǎn)來看,它可能讓你付出一定的代價。

菱形繼承問題

利用繼承可以將一類中的屬性傳遞給其他類。但是,如果你想混合兩個不同類的屬性怎么辦?

沒錯,這無法完成,至少常規(guī)的方法都不行。以 Copier 類為例(在此引用以下鏈接文章中的例子:https://medium.com/@cscalfani/goodbye-object-oriented-programming-a59cda4c0e53),Copier 將掃描文件的內(nèi)容并將其打印在白紙上。那么它應(yīng)該是 Scanner 還是 Printer 的子類?

這個問題根本沒有完美的答案。即使這個問題不會破壞你的代碼,但它經(jīng)常出現(xiàn),會讓人很沮喪。

層級問題

在菱形繼承問題中,Copier 是哪個類的子類是問題的關(guān)鍵所在。但或許有個投機取巧的方案:假設(shè) Copier 是父類,Scanner 和 Printer 是僅繼承屬性子集的子類,那么問題就解決了。

但如果你的 Copier 是黑白的,而 Printer 也能夠處理彩色,那怎么辦?從這個意義上說,Printer 不是 Copier 的一種泛化嗎?如果 Printer 連接了 WiFi,而 Copier 沒有呢?

類上堆積的屬性越多,建立適當(dāng)?shù)膶哟谓Y(jié)構(gòu)就越困難。在你所處理的屬性集群中,Copier 共享了 Printer 的一些屬性,但不是全部屬性,反之亦然。在大型復(fù)雜項目中,層次結(jié)構(gòu)的問題會導(dǎo)致很大的混亂。


引用問題

你可能會想到進(jìn)行沒有層次結(jié)構(gòu)的面向?qū)ο缶幊?。我們可以使用屬性集群,并根?jù)需要繼承、擴展或重寫屬性。也許這有點混亂,但這將是對當(dāng)前問題的準(zhǔn)確表示。

這里只存在一個問題:封裝的全部目的是使數(shù)據(jù)片段彼此之間保持安全,從而使計算效率更高,但沒有嚴(yán)格的層次結(jié)構(gòu),這是行不通的。

假設(shè)一個對象 A 通過與另一個對象 B 交互來覆蓋層次結(jié)構(gòu),會發(fā)生什么情況?其他關(guān)系的情況并不重要,但當(dāng) B 不是 A 的直接父類時,A 必須包含 B 的全部私有引用,否則,它們將無法交互。

但是,如果 A 包含 B 的子類也具有的信息,那么就可以在多個位置修改該信息。因此,有關(guān) B 的信息已經(jīng)不再安全,并且封裝已經(jīng)被破壞。

盡管許多面向?qū)ο蟮某绦騿T都使用這種架構(gòu)來構(gòu)建程序,但這并不是面向?qū)ο缶幊?,只是一團糟。

單一范式存在的風(fēng)險

以上 5 個問題的共同點是它們都存在不合適的繼承。由于繼承沒有包含在面向?qū)ο缶幊痰脑夹问街?,所以這些問題可能不能稱為面向?qū)ο蟊旧淼膯栴}。

但是也并不是只有面向?qū)ο缶幊虝豢浯蟆T诩兇獾暮瘮?shù)式編程中,處理用戶的輸入或在屏幕上輸出消息極其困難。對此,面向?qū)ο蠡蛎嫦蜻^程編程會好很多。

但仍然有一些開發(fā)人員試圖將這些東西用純函數(shù)的方式實現(xiàn),并且編寫幾十行沒人能看懂的代碼。而使用另一種范式就能夠輕松地將代碼簡化為幾行可讀的代碼。

毫無疑問,函數(shù)式編程正在得到更多關(guān)注,而面向?qū)ο缶幊探鼛啄暝獾揭恍┰嵅 A私庑碌木幊谭妒讲⒃谶m當(dāng)?shù)臅r候使用它們是很有意義的。無論哪種編程范式,都不需要只遵循一種,在適當(dāng)?shù)臅r候使用不同的編程范式才能更好地解決問題。

審核編輯 黃昊宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
收藏 人收藏

    評論

    相關(guān)推薦

    工業(yè) 4.0 時代:連接器不容忽視的挑戰(zhàn)與高效應(yīng)對方案

    工業(yè)4.0時代的到來,制造業(yè)已趨向自動化、智能化和高效化。這要求生產(chǎn)設(shè)備具備更高的靈活性和可靠性,連接器作為連接電子設(shè)備和電路的部件,連接器的性能和功能需求也相應(yīng)提升,需要滿足更復(fù)雜的工業(yè)應(yīng)用場景。連接器市場面臨的挑戰(zhàn)1.產(chǎn)品迭代帶來的靈活性挑戰(zhàn)在下游產(chǎn)業(yè)中,產(chǎn)品和技術(shù)更新?lián)Q代的速度快。以汽車領(lǐng)域為例,新車型不斷涌現(xiàn),這就要求連接器具備高度的靈活性,能滿足多
    的頭像 發(fā)表于 10-30 08:08 ?214次閱讀
    工業(yè) 4.0 時代:連接器<b class='flag-5'>不容忽視</b>的挑戰(zhàn)與高效應(yīng)對方案

    不容忽視的PCB測試點,關(guān)鍵時刻可以避免批量事故哦!

    it Test Point in English. NOKIA手機的測試點有什么用? 為什么要留兩排測試點? 我雖然不知道NOKIA手機這些測試點的具體作用,但我大概可以猜測出來: 供電:包括至少一個Vbat
    的頭像 發(fā)表于 10-08 06:58 ?168次閱讀
    <b class='flag-5'>不容忽視</b>的PCB測試點,關(guān)鍵時刻可以避免批量事故哦!

    如何利用電源濾波器降低電源噪聲

    在電子設(shè)備的設(shè)計與運行中,電源噪聲是一個不容忽視的問題。它不僅會影響設(shè)備的性能穩(wěn)定性,還可能對信號質(zhì)量造成干擾,甚至導(dǎo)致設(shè)備故障。
    的頭像 發(fā)表于 09-26 10:21 ?174次閱讀

    不容忽視的PCB設(shè)計細(xì)節(jié)

    比起低價壓力、緊迫交期、嚴(yán)苛品質(zhì)、貨款拖延等常規(guī)煩惱,訂單里那些不起眼的設(shè)計失誤和小BUG,帶來的影響更叫人腦殼疼!
    發(fā)表于 04-10 11:46 ?348次閱讀
    <b class='flag-5'>不容忽視</b>的PCB設(shè)計細(xì)節(jié)

    工業(yè)安全不容忽視 防止意外傷害的發(fā)生

    機械工控機
    jf_18500570
    發(fā)布于 :2024年04月07日 10:18:37

    PCB設(shè)計細(xì)節(jié)不容忽視,SMT行業(yè)大佬這樣說

    的是0402的小電阻 ,但 PCB對應(yīng)的焊盤卻是1206的 ,怎么搭得上呢? 雖然物料才15塊一盤,但為了這個小小的電阻,我們得從華強北加急采購,還得花上150的跑腿費。 而SMT線還在等著,誤工
    發(fā)表于 04-02 20:38

    工業(yè)安全 不容忽視

    自動化機械臂
    jf_18500570
    發(fā)布于 :2024年03月30日 10:12:49

    不容忽視的小電阻:CAN(FD)終端電阻在汽車通信中的關(guān)鍵角色

    CAN總線終端電阻,顧名思義就是加在總線末端的電阻。此電阻雖小,但在CAN總線通信中卻有十分重要的作用。終端電阻的作用CAN總線終端電阻的作用有兩個:提高抗干擾能力,確??偩€快速進(jìn)入隱性狀態(tài);提高信號質(zhì)量。提高抗干擾能力CAN總線有“顯性”和“隱性”兩種狀態(tài),“顯性”代表“0”,“隱性”代表“1”,由CAN收發(fā)器決定。圖1是一個CAN收發(fā)器的典型內(nèi)部結(jié)構(gòu)圖,
    的頭像 發(fā)表于 01-19 08:24 ?2403次閱讀
    <b class='flag-5'>不容忽視</b>的小電阻:CAN(FD)終端電阻在汽車通信中的關(guān)鍵角色

    比亞迪躍居全球最大純電動車制造商,特斯拉市值縮水2319.84億

    盡管比亞迪在AI及自動駕駛領(lǐng)域相對低調(diào),但其龐大的資金實力和技術(shù)實力不容忽視。值得注意的是,在FSD和Optimus實現(xiàn)商業(yè)化前,特斯拉仍高度依賴汽車銷售。
    的頭像 發(fā)表于 01-04 10:50 ?553次閱讀

    三星電子也要自研智能傳感器?

    智能傳感器在半導(dǎo)體制造過程中的重要性不容忽視。精確測量和管理等離子體條件,是提高半導(dǎo)體良率和產(chǎn)量的關(guān)鍵。
    發(fā)表于 12-29 14:16 ?632次閱讀

    基于C/C++面向對象的方式封裝socket通信類流程簡析

    在掌握了基于 TCP 的套接字通信流程之后,為了方便使用,提高編碼效率,可以對通信操作進(jìn)行封裝,本著有淺入深的原則,先基于 C 語言進(jìn)行面向過程的函數(shù)封裝,然后再基于 C++ 進(jìn)行面向對象的類封裝。
    的頭像 發(fā)表于 12-26 10:00 ?1695次閱讀

    基于C/C++面向對象的方式封裝socket通信類

    在掌握了基于 TCP 的套接字通信流程之后,為了方便使用,提高編碼效率,可以對通信操作進(jìn)行封裝,本著有淺入深的原則,先基于 C 語言進(jìn)行面向過程的函數(shù)封裝,然后再基于 C++ 進(jìn)行面向對象的類封裝。
    的頭像 發(fā)表于 12-26 09:57 ?1266次閱讀

    電源過沖對數(shù)字電路有哪些潛在的影響?

    電源過沖對數(shù)字電路的影響是一個絕對不容忽視的問題,因為它可能對電路的性能和穩(wěn)定性產(chǎn)生極其負(fù)面的影響。
    的頭像 發(fā)表于 12-13 11:41 ?748次閱讀

    高壓電線工作原理與傳輸損耗

    盡管高壓電線為我們的生活帶來了便利,但其潛在危害不容忽視。長期的電磁輻射暴露可能對人體健康產(chǎn)生不良影響,如癌癥和神經(jīng)系統(tǒng)疾病的風(fēng)險增加。
    的頭像 發(fā)表于 11-30 11:15 ?1632次閱讀