一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

面向對象編程:這里我說了算!

  英文原文:I give the orders around here! 

  自從 9 歲那年得到第一臺 Commodore 64 家用電腦起,我就開始編程。然而,當面對如何寫出好的代碼時,我仍然感覺自己還有很多要學的。

  在探索如何提高自己的過程中,我學了很多種語言。大多數是以面向對象為主的(OO)。

  然而,讓我驚訝的是,在我讀過的大多數書本、雜志和網上文章中,有著大量遭透了的被當作面向對象例子的代碼。

  這些代碼中,我看到的最多被違反的原則是“命令,不要去詢問(Tell, Don’t Ask)”原則。這個原則講的是,一個對象應該命令其它對象該做什么,而不是去查詢其它對象的狀態來決定做什么(查詢其它對象的狀態來決定做什么也被稱作‘功能嫉妒(Feature Envy)’)。在面向對象的編程中,一個對象被定義成由對象狀態和操作這個狀態的方法組成。

  在《Holub on Patterns: Learning Design Patterns By Looking At Code》這本書里,Allen Holub 在第一章里有一節的標題是“為什么 getter 和 setter 方法有害”。他在 JavaWorld 上的一篇文章里也談論了這個問題。對所有的面向對象的程序員來說,這應該是一篇“必讀”文章。

  我有一些程序員同事,他們在一個對象上第一步聲明了屬性后,第二步就是添加 getter 和 setter 方法。JavaBean 規范對于這種文化的推廣負于很大的責任。人們認為這是一種能讓你寫出可復用的模塊化組建的好方法,但這已是很多年前的事了,時過境遷。

  寫帶有 getter 和 setter 方法的類會導致過程式的代碼。通過 getter 和 setter 來獲取數據進行操作的邏輯最終會遍布整個應用,進而經常導致應用內的重復(這違反了另外一個原則:DRY——不要自我重復(Don’t Repeat Yourself))。這會致使產生很難維護的代碼,當你對一個類做任何修改時,都會在整個應用內造成連鎖式的牽連。

  用這種方式來暴露數據還會妨礙你重構你的類,因為對這樣的屬性的任何修改都意味著會影響到訪問了這個屬性的其它類。

  違反“命令,不要去詢問”原則的另外一個副作用是,你的探詢最終變成嚴重依賴狀態信息并帶有很多前提條件。這會讓人很難理解你究竟詢問的是什么。

  你很可能會最終違反的第三個原則是,盡少知道(Least Knowledge)原則,也叫做得墨忒耳定律(Law Of Demeter)。這個定律可以總結為下面一句好:

一個類應該只跟它的直接朋友通話,不要跟陌生人說話。

  在類里面加入 getter 方法,你的代碼最終會寫成這樣:

if (person.getAddress () .getCountry () == "Australia") {

it知識庫面向對象編程:這里我說了算!,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 自拍三区 | 中文字幕一区二区三区四区五区 | 婷婷国产 | 日本一二三区免费 | 98香蕉草草视频在线精品看 | 国产精品久久久福利 | 伊人国产在线视频 | 欧美一a一片一级一片 | 国外免费精品视频在线观看 | 美女一级毛片视频 | 欧洲在线免费视频 | 美女扒开下面无遮挡免费视频 | 日韩视频精品在线 | 天天擦天天干 | 亚洲一区亚洲二区 | 亚洲欧美成人影院 | 日本精品一区二区三区视频 | 四虎国产精品免费久久久 | 激情免费网站 | 麻豆xfplay国产在线观看 | 99午夜高清在线视频在观看 | 国产成人精品一区二区免费 | 成人97 | 91精品国产高清91久久久久久 | 目韩一区二区三区系列片丶 | 精品视频一区二区三区在线观看 | 五月婷婷激情四射 | 级毛片久久久毛片精品毛片 | 色老板网站 | 天天干在线影院 | 欧美一级特黄aaa大片 | 欧美亚洲激情在线 | www五月婷婷| 一级做a爰久久毛片武则天 一级做a爰毛片 | 久久亚洲精品成人综合 | 精品中文字幕乱码一区二区 | 看全色黄大色黄大片视频 | 手机在线观看亚洲国产精品 | 手机在线色 | 国产精品久久久久影院色 | 韩国一级毛片视频免费观看 |