《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 業界動態 > 面向對象編程會被拋棄嗎?

面向對象編程會被拋棄嗎?

2020-10-14
來源:機器之心

  今天來講講面向對象編程中比較棘手的問題。

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

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

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

  盡管這個想法很巧妙,但直到 1981 年,面向對象編程才成為主流。在那之后,它就沒有停止過吸引新的和經驗豐富的軟件開發者。面向對象的程序員市場一如既往地忙碌。

  但是在最近幾年中,這種已有幾十年歷史的編程范式受到越來越多的批評。難道是在面向對象編程大行其道 40 年之后,技術已經超越了這種范式?

  函數和數據耦合

  面向對象編程的主要思想非常簡單:嘗試將一個功能強大的程序整體分解為功能同樣強大的多個部分。這樣就可以將一些數據和那些只在相關數據上使用的函數耦合起來。

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

  繼承性和多態性并沒有包含在最初的設計想法中,但是對于現在的面向對象編程而言是必需的。繼承基本上意味著開發者可以定義具有其父類所有屬性的子類。直到 1976 年,即面向對象的程序設計的概念問世十年之后,繼承性才被引入。

  又過了十年,多態性才進入面向對象的編程。簡單來講,這意味著某種方法或對象可以用做其他方法或對象的模板。從某種意義上說,多態性是繼承性的泛化,因為并不是原始方法或對象的所有屬性都需要傳輸到新實體。相反,你還可以選擇重寫一些屬性。

  多態性的特殊之處在于,即使兩個實體在源代碼中互相依賴,被調用實體的工作方式也更像插件。這使得開發人員的工作變得輕松,因為他們不必擔心運行時的依賴關系。

  值得一提的是,繼承性和多態性并不是面向對象編程所特有的。真正的區別在于封裝數據及其包含的方法。在計算資源比今天稀缺得多的時代,這是一個天才的想法。

微信圖片_20201014133909.png

  面向對象編程中的 5 大問題

  面向對象的編程一經問世,便改變了開發人員看待代碼的方式。20 世紀 80 年代以前,過程式編程非常面向機器。開發人員需要非常了解計算機的工作原理才能編寫好的代碼。

  通過封裝數據和其他方法,面向對象的編程使軟件開發更加以人為中心,符合人類的直覺。比如,方法 drive() 屬于 car 數據組,而不是 teddybear 組。之后出現的繼承性也很直觀。比如,現代汽車(Hyundai)是汽車的一個子類,并且具有相同的屬性,但 PooTheBear 不是,這樣很好理解。

  香蕉猴子叢林問題

  想象一下,你正在設置一個新程序,并且正在考慮設計一個新類。然后,你回想起為另一個項目創建的簡潔的小類,發現其對正在進行的工作很合適。

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

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

  Erlang 的創建者 Joe Armstrong 曾有一句名言:「面向對象語言的問題在于,它們自帶其自身周圍的所有隱式環境。你想要香蕉,但是得到的卻是拿著香蕉的大猩猩和整個叢林。」

  這幾乎可以說明一切。復用類是可以的,實際上這可能是面向對象編程的主要優點,但不要將其發揮到極致。有時你應該建立一個新的類,而不是添加大量依賴項。

  脆弱的基類問題

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

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

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

  菱形繼承問題

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

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

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

  層級問題

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

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

  類上堆積的屬性越多,建立適當的層次結構就越困難。在你所處理的屬性集群中,Copier 共享了 Printer 的一些屬性,但不是全部屬性,反之亦然。在大型復雜項目中,層次結構的問題會導致很大的混亂。

  引用問題

  你可能會想到進行沒有層次結構的面向對象編程。我們可以使用屬性集群,并根據需要繼承、擴展或重寫屬性。也許這有點混亂,但這將是對當前問題的準確表示。

  這里只存在一個問題:封裝的全部目的是使數據片段彼此之間保持安全,從而使計算效率更高,但沒有嚴格的層次結構,這是行不通的。

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

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

  盡管許多面向對象的程序員都使用這種架構來構建程序,但這并不是面向對象編程,只是一團糟。

  單一范式存在的風險

  以上 5 個問題的共同點是它們都存在不合適的繼承。由于繼承沒有包含在面向對象編程的原始形式中,所以這些問題可能不能稱為面向對象本身的問題。

  但是也并不是只有面向對象編程會被夸大。在純粹的函數式編程中,處理用戶的輸入或在屏幕上輸出消息極其困難。對此,面向對象或面向過程編程會好很多。

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

  毫無疑問,函數式編程正在得到更多關注,而面向對象編程近幾年遭到一些詬病。了解新的編程范式并在適當的時候使用它們是很有意義的。無論哪種編程范式,都不需要只遵循一種,在適當的時候使用不同的編程范式才能更好地解決問題。

微信圖片_20201014133919.png

  面向對象編程真的要被取代了嗎?

  面對越來越多的問題,函數式編程可能是更有效的一種選擇。數據分析、機器學習、并行編程,這些領域你投入的越多,你就會越喜歡函數式編程。

  但是目前面向對象開發的程序員的崗位需求量依然比函數式編程開發程序員多得多。但是這也并不意味著你不能成為后者,函數式編程開發的程序員目前仍然比較稀缺。

  最有可能的情況是,面向對象的編程將會繼續存在十年左右。當然,選擇相對前衛的方式是好的,但這并不意味著你應該放棄面向對象編程。所以在接下來的幾年中,不要完全放棄它,但至少確保它不是你唯一掌握的程序設計方式。

  

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
久久riav二区三区| 欧美涩涩视频| 中日韩高清电影网| 亚洲精品免费网站| 亚洲国产精选| 亚洲国产精品一区二区第四页av | 日韩视频一区| 亚洲精品网站在线播放gif| 亚洲电影成人| 久久狠狠一本精品综合网| 欧美伊人久久久久久久久影院| 午夜精彩国产免费不卡不顿大片| 亚洲小说欧美另类社区| 正在播放亚洲一区| 亚洲一二三级电影| 亚洲女性裸体视频| 亚洲欧美成人一区二区三区| 亚洲欧美日韩精品久久久久| 香蕉久久夜色精品国产| 亚洲欧美美女| 久久电影一区| 亚洲激情视频在线播放| 亚洲区一区二区三区| 亚洲精品中文在线| 亚洲精品一区二区三区福利| 亚洲免费av网站| 在线一区二区三区四区五区| 亚洲自拍偷拍一区| 久久av一区二区三区漫画| 久久精品综合网| 久久综合网络一区二区| 欧美国产日韩a欧美在线观看| 欧美精品三级日韩久久| 欧美日韩一卡二卡| 国产精品亚洲аv天堂网| 国产色产综合产在线视频| 狠狠色噜噜狠狠色综合久| 在线精品视频免费观看| 日韩视频―中文字幕| 亚洲一区二区三区四区视频| 午夜久久久久久久久久一区二区| 亚洲国产1区| 日韩视频国产视频| 亚洲欧美清纯在线制服| 久久久人人人| 欧美日韩成人在线观看| 国产伦精品一区二区三区四区免费| 国内外成人免费视频 | 亚洲精品视频二区| 亚洲综合视频网| 久久男人资源视频| 欧美日韩国产大片| 国产人久久人人人人爽| 亚洲国产精品va在看黑人| 中文日韩电影网站| 亚洲国产精品久久久久秋霞影院| 在线一区二区日韩| 久久久久久久精| 欧美精品综合| 国产丝袜一区二区三区| 亚洲激情社区| 亚洲欧美日本另类| 亚洲精品一区在线观看香蕉| 香蕉久久夜色精品国产使用方法| 巨乳诱惑日韩免费av| 国产精品h在线观看| 伊人久久综合97精品| 在线亚洲免费视频| 亚洲欧洲日本mm| 亚洲欧美视频一区| 欧美国产综合一区二区| 国产精品亚洲人在线观看| 亚洲黄色av一区| 欧美一二三视频| avtt综合网| 久久一本综合频道| 国产精品视频一区二区三区| 亚洲激情一区二区三区| 午夜视频一区二区| 亚洲视频在线免费观看| 久久这里有精品15一区二区三区 | 国产精品久久久久久模特| 一区二区在线观看视频| 亚洲永久在线| 99日韩精品| 老色批av在线精品| 国产精品日本一区二区| 亚洲伦理中文字幕| 亚洲欧洲日韩在线| 久久久欧美精品| 国产精品美女www爽爽爽| 亚洲精品一区二区三区樱花| 亚洲电影观看| 久久精品在线| 国产精品伊人日日| 在线亚洲成人| 一区二区免费在线播放| 欧美成人免费视频| 国语自产精品视频在线看抢先版结局 | 亚洲欧美久久久| 欧美日韩国产三级| 亚洲电影av在线| 久久av一区二区三区| 欧美一区二区在线免费观看| 国产精品久久久久99| av成人免费在线观看| 99re在线精品| 欧美好骚综合网| 亚洲激情电影在线| 亚洲精品乱码久久久久久按摩观| 久久久久久亚洲综合影院红桃 | 亚洲女性喷水在线观看一区| 亚洲在线播放| 欧美午夜电影在线| 日韩视频免费| 在线视频欧美日韩| 欧美日韩午夜剧场| 日韩午夜在线| 亚洲视频精品在线| 欧美系列亚洲系列| 一区二区三区 在线观看视| 中文精品99久久国产香蕉| 欧美日韩国产成人在线观看| 日韩午夜免费视频| 亚洲一区二区精品在线| 国产精品九九| 午夜精品美女久久久久av福利| 欧美一区1区三区3区公司| 国产日产欧产精品推荐色 | 亚洲第一区在线观看| 巨乳诱惑日韩免费av| 在线观看一区视频| 亚洲精品欧美日韩专区| 欧美另类一区二区三区| 亚洲精品永久免费| 亚洲欧美韩国| 国产视频一区三区| 亚洲国产成人午夜在线一区| 久久综合久久美利坚合众国| 在线不卡免费欧美| 一本大道久久a久久精二百| 欧美性开放视频| 亚洲欧美成人在线| 久久久久久久久一区二区| 亚洲盗摄视频| 中文高清一区| 国产精品一区二区在线观看不卡| 午夜久久久久| 免费成人黄色| 日韩网站在线| 午夜免费日韩视频| 黄色欧美成人| 一本色道久久综合精品竹菊| 国产精品高潮粉嫩av| 欧美与欧洲交xxxx免费观看| 玖玖玖国产精品| 99亚洲精品| 欧美一区二区精美| **性色生活片久久毛片| 中文亚洲欧美| 国产欧美日韩在线观看| 亚洲黄一区二区| 欧美午夜精品久久久久免费视| 午夜精品一区二区在线观看| 欧美91视频| 中文欧美在线视频| 久久一区二区三区国产精品 | 欧美在线视频一区二区三区| 欧美a级在线| 一本色道久久综合| 久久久久久久久综合| 亚洲精品视频啊美女在线直播| 性欧美大战久久久久久久免费观看 | 亚洲精品小视频在线观看| 欧美一区二区在线免费观看| 亚洲高清电影| 欧美一区二区精美| 亚洲激情网站免费观看| 欧美一区午夜精品| 亚洲激情啪啪| 久久精品亚洲乱码伦伦中文 | 亚洲性xxxx| 国产在线欧美日韩| 亚洲午夜精品一区二区| 黑人巨大精品欧美一区二区 | 欧美大片va欧美在线播放| 亚洲免费视频中文字幕| 模特精品在线| 香蕉成人伊视频在线观看| 欧美日韩国产一区二区| 欧美在线免费视屏| 欧美午夜寂寞影院| 亚洲精选视频免费看| 国产日韩欧美高清| 亚洲影视中文字幕| 亚洲精品综合久久中文字幕| 久久久国产精彩视频美女艺术照福利| 99re6热只有精品免费观看 | 亚洲国产欧美日韩| 国产欧美日韩亚洲精品|