get與set成員函數(shù)是為代碼耦合之重要原因
版本:0.1
最后修改:2009-08-21
撰寫:李現(xiàn)民
類數(shù)據(jù)成員的訪問級(jí)別通常需定義為private,以封裝類的實(shí)現(xiàn)細(xì)節(jié),這樣可以在類的生命演化過程中提供更好實(shí)現(xiàn)彈性。
get/set成員函數(shù)(訪問級(jí)別通常為public)使得client端用戶代碼可以訪問對(duì)象的內(nèi)部數(shù)據(jù)結(jié)構(gòu),這會(huì)暴露類內(nèi)部的實(shí)現(xiàn)細(xì)節(jié)。這種暴露使會(huì)得用戶代碼與類實(shí)現(xiàn)之間產(chǎn)生深層次的依賴關(guān)系,而這種過剩的知識(shí)將在類實(shí)現(xiàn)技術(shù)改變時(shí)迅速破壞相關(guān)的用戶代碼---漣漪效果。
比如Container類輸出了關(guān)于實(shí)現(xiàn)該類之二叉樹的信息(比如,當(dāng)它輸出成員函數(shù)getLeftChild()與getRightChild()時(shí)),用戶將被迫按照二叉樹而不是容器進(jìn)行思考,這將使用戶代碼變得復(fù)雜且難以改變。如果Container類改變了實(shí)現(xiàn)結(jié)構(gòu),則用戶代碼將被迫進(jìn)行修改(可能是大量的)。
最少知識(shí)(least
knowledge)原則是用于面向?qū)ο缶幋a中降低類間耦合度的指導(dǎo)原則。該原則認(rèn)為如果要在相互調(diào)用的類(對(duì)象)之間保持較低的耦合度,則一個(gè)對(duì)象所調(diào)用的方法應(yīng)該僅僅局限于以下幾個(gè)來源:
-
類對(duì)象本身;
-
被當(dāng)作方法的參數(shù)而傳遞進(jìn)來的對(duì)象;
-
此方法所創(chuàng)建或?qū)嵗娜魏螌?duì)象;
-
對(duì)象的任何組件;
一個(gè)對(duì)象可以任意調(diào)用以上四類對(duì)象的方法。唯一一類不可調(diào)用的方法來源于:通過某個(gè)對(duì)象的get成員函數(shù)所獲取的間接對(duì)象的成員函數(shù)。很容易想象,當(dāng)某個(gè)類擁有大量get/set成員函數(shù)時(shí),該類本身幾乎不可能提供完善的邏輯處理方法(否則也就沒有必要提供這些get/set成員函數(shù)了),因此借助get成員函數(shù)獲取間接對(duì)象并做進(jìn)一步的處理幾乎是不可避免的。
因此,在有可能的情況下,類設(shè)計(jì)人員應(yīng)該盡量不提供get與set成員函數(shù)。
當(dāng)然,不要認(rèn)為get與set成員函數(shù)總是壞的,像CORBA這樣的框架都會(huì)為所有的屬性自動(dòng)提供get/set成員函數(shù)。真正的問題是:好的對(duì)象總會(huì)封裝并在接口后面隱藏某些東西,然而get/set成員函數(shù)有時(shí)會(huì)在暗中暴露對(duì)象的秘密。只有當(dāng)在類外(從用戶的角度)看待這些私有數(shù)據(jù)仍“有意義”時(shí),為私有數(shù)據(jù)設(shè)置公有的get()和set()成員函數(shù)才是合理的。然而在許多情況下,
get()/set()成員函數(shù)和公有數(shù)據(jù)一樣差勁:它們僅僅隱藏了私有數(shù)據(jù)的名稱,而沒有隱藏私有數(shù)據(jù)本身。
注1:以上文字部分參考了《C++
FAQs》second edition,
P73的內(nèi)容。
注2:我們經(jīng)常使用get/set成員函數(shù)作為急救帶來修補(bǔ)蹩腳的接口。