99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

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

面向?qū)ο缶幊虝?huì)被拋棄嗎?這5大問(wèn)題不容忽視

電子設(shè)計(jì) ? 來(lái)源:電子設(shè)計(jì) ? 作者:電子設(shè)計(jì) ? 2020-10-30 12:03 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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

盡管這個(gè)想法很巧妙,但直到 1981 年,面向?qū)ο缶幊滩懦蔀橹髁?。在那之后,它就沒(méi)有停止過(guò)吸引新的和經(jīng)驗(yàn)豐富的軟件開(kāi)發(fā)者。面向?qū)ο蟮?a target="_blank">程序員市場(chǎng)一如既往地忙碌。

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

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

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

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

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

又過(guò)了十年,多態(tài)性才進(jìn)入面向?qū)ο蟮木幊?。?jiǎn)單來(lái)講,這意味著某種方法或?qū)ο罂梢杂米銎渌椒ɑ驅(qū)ο蟮哪0?。從某種意義上說(shuō),多態(tài)性是繼承性的泛化,因?yàn)椴⒉皇窃挤椒ɑ驅(qū)ο蟮乃袑傩远夹枰獋鬏數(shù)叫聦?shí)體。相反,你還可以選擇重寫(xiě)一些屬性。

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

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


面向?qū)ο缶幊讨械?5 大問(wèn)題

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

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

香蕉猴子叢林問(wèn)題

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

沒(méi)問(wèn)題,你可以將以前項(xiàng)目中的類在新項(xiàng)目中復(fù)用。

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

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

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


脆弱的基類問(wèn)題

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

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

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

菱形繼承問(wèn)題

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

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

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

層級(jí)問(wèn)題

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

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

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


引用問(wèn)題

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

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

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

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

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

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

以上 5 個(gè)問(wèn)題的共同點(diǎn)是它們都存在不合適的繼承。由于繼承沒(méi)有包含在面向?qū)ο缶幊痰脑夹问街校赃@些問(wèn)題可能不能稱為面向?qū)ο蟊旧淼膯?wèn)題。

但是也并不是只有面向?qū)ο缶幊虝?huì)被夸大。在純粹的函數(shù)式編程中,處理用戶的輸入或在屏幕上輸出消息極其困難。對(duì)此,面向?qū)ο蠡蛎嫦蜻^(guò)程編程會(huì)好很多。

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

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

審核編輯 黃昊宇

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    不良瓷嘴導(dǎo)致LED斷線死燈問(wèn)題多,瓷嘴優(yōu)化刻不容

    在LED封裝領(lǐng)域,焊線工藝是確保器件性能與可靠性的核心環(huán)節(jié)。而瓷嘴,作為焊線工藝中一個(gè)看似微小卻極為關(guān)鍵的部件,其對(duì)引線鍵合品質(zhì)的影響不容忽視。大量失效分析案例證明,LED封裝器件的死燈失效絕大多數(shù)
    的頭像 發(fā)表于 06-12 14:03 ?171次閱讀
    不良瓷嘴導(dǎo)致LED斷線死燈問(wèn)題多,瓷嘴優(yōu)化刻<b class='flag-5'>不容</b>緩

    FLIR Si2x防爆聲學(xué)成像儀為工業(yè)安全保駕護(hù)航

    粉塵爆炸是工業(yè)環(huán)境中不容忽視的重大安全隱患,尤其在ATEX 22區(qū),其潛在威脅不容忽視。為了有效應(yīng)對(duì)這一挑戰(zhàn),F(xiàn)LIR Si2x聲學(xué)成像儀應(yīng)運(yùn)而生。它能夠精確檢測(cè)壓縮空氣泄漏與機(jī)械故障的聲音信號(hào),幫助我們及時(shí)發(fā)現(xiàn)并處理潛在風(fēng)險(xiǎn)點(diǎn),從而有效預(yù)防粉塵爆炸事故的發(fā)生,確保工業(yè)生
    的頭像 發(fā)表于 05-23 14:40 ?305次閱讀

    完整版—單片機(jī)編程思想(推薦下載?。?/a>

    第3章直接針對(duì)我們?cè)趯?shí)際工作中經(jīng)常遇到的問(wèn)題——多定時(shí)器、多延時(shí)器問(wèn)題進(jìn)行多線程編程實(shí)現(xiàn),并在實(shí)現(xiàn)過(guò)程中引入消息處理機(jī)制。通過(guò)前3章的技術(shù)準(zhǔn)備,在第4章正式提出面向對(duì)象編程思路。第
    發(fā)表于 04-16 15:06

    海瑞思推出手持VOCs檢測(cè)儀HV-1001

    在現(xiàn)代生產(chǎn)生活中,揮發(fā)性有機(jī)化合物(VOCs)的危害不容忽視。這些物質(zhì)不僅對(duì)人體健康具有潛在威脅,還可能對(duì)環(huán)境造成污染。
    的頭像 發(fā)表于 03-18 15:50 ?319次閱讀

    微型導(dǎo)軌在半導(dǎo)體設(shè)備中如何防止磨損?

    微型導(dǎo)軌在半導(dǎo)體設(shè)備中承載著執(zhí)行精確定位運(yùn)動(dòng)控制的重任,其磨損問(wèn)題不容忽視。
    的頭像 發(fā)表于 02-06 18:01 ?409次閱讀
    微型導(dǎo)軌在半導(dǎo)體設(shè)備中如何防止磨損?

    為安全生產(chǎn)保駕護(hù)航 KMWIS無(wú)線智能傳感器助力上海匯眾汽車(chē)制造有限公司產(chǎn)線上振動(dòng)日常巡檢!

    ,設(shè)備產(chǎn)生振動(dòng)異常往往是一個(gè)不容忽視的信號(hào),它可能預(yù)示著潛在的設(shè)備故障或性能下降。一旦發(fā)現(xiàn)振動(dòng)異常,應(yīng)立即采取行動(dòng),以免小問(wèn)題演變成大問(wèn)題,影響生產(chǎn)線的正常運(yùn)轉(zhuǎn)。
    的頭像 發(fā)表于 01-17 10:57 ?408次閱讀
    為安全生產(chǎn)保駕護(hù)航 KMWIS無(wú)線智能傳感器助力上海匯眾汽車(chē)制造有限公司產(chǎn)線上振動(dòng)日常巡檢!

    gitee 支持的編程語(yǔ)言有哪些

    Gitee 支持的常見(jiàn)編程語(yǔ)言: Python :一種廣泛使用的高級(jí)編程語(yǔ)言,以其清晰的語(yǔ)法和代碼可讀性而聞名。 Java :一種面向對(duì)象編程
    的頭像 發(fā)表于 01-06 09:50 ?647次閱讀

    深入解析:海外IP代理在跨境電商與數(shù)據(jù)分析中的應(yīng)用

    海外IP代理在跨境電商與數(shù)據(jù)分析中的應(yīng)用廣泛,其重要性不容忽視。
    的頭像 發(fā)表于 11-20 08:27 ?623次閱讀

    編程語(yǔ)言的誤區(qū)與常見(jiàn)問(wèn)題

    誤區(qū)一:編程語(yǔ)言的選擇 常見(jiàn)問(wèn)題: 初學(xué)者在選擇編程語(yǔ)言時(shí),往往會(huì)被市場(chǎng)上的熱門(mén)語(yǔ)言所吸引,而忽視了自己的實(shí)際需求和興趣。 一些開(kāi)發(fā)者認(rèn)為某種編程
    的頭像 發(fā)表于 11-15 09:35 ?728次閱讀

    為什么選不中PCB上的對(duì)象

    圖就是一個(gè)封裝的“鎖定”屬性: “鎖定”用來(lái)確保對(duì)象會(huì)被誤操作修改,所以被“鎖定”的du當(dāng)然輕易是選不中的(默認(rèn)情況)!對(duì)于PCB中已經(jīng)完全布局、布線且不希望被改動(dòng)的對(duì)象,就可以進(jìn)行“鎖定”操作。 如果需要編輯“鎖定”的
    的頭像 發(fā)表于 11-12 12:23 ?2643次閱讀
    為什么選不中PCB上的<b class='flag-5'>對(duì)象</b>?

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

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

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

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

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

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

    PCB想要做好鋪銅,這幾點(diǎn)不容忽視!

    一站式PCBA智造廠家今天為大家講講高速PCB設(shè)計(jì)當(dāng)中鋪銅處理方法有哪些?高速PCB設(shè)計(jì)鋪銅的正確處理方法。在高速PCB設(shè)計(jì)中,鋪銅的處理對(duì)于確保信號(hào)完整性和電磁兼容性至關(guān)重要。 高速PCB設(shè)計(jì)中正確處理鋪銅的方法: 1. 差分對(duì)鋪銅: 對(duì)于差分信號(hào),確保它們?cè)谙噜弻由嫌邢嗟惹蚁喾吹匿併~。這有助于提高信號(hào)的免疫性,減小串?dāng)_,并提高差分信號(hào)的質(zhì)量。 2. 規(guī)遍鋪銅: 在高速PCB中,規(guī)遍(Ground Plane)是非常重要的。在每一層中都鋪上規(guī)遍銅,可以提供
    的頭像 發(fā)表于 07-30 09:21 ?955次閱讀

    人員定位管理系統(tǒng)有怎樣優(yōu)勢(shì)?4點(diǎn)不可忽視

    情況外,人員定位管理系統(tǒng)還可以查看實(shí)時(shí)畫(huà)面,若工作人員誤闖某個(gè)區(qū)域,系統(tǒng)就會(huì)自動(dòng)報(bào)警。這樣也是為了防止工作人員的誤入,以免造成不必要安全隱患。對(duì)于該系統(tǒng),四點(diǎn)功能是不可忽視的,有了它們廠區(qū)的安全隱患才能得
    的頭像 發(fā)表于 07-16 11:05 ?863次閱讀
    人員定位管理系統(tǒng)有怎樣優(yōu)勢(shì)?<b class='flag-5'>這</b>4點(diǎn)不可<b class='flag-5'>忽視</b>