/* +-------------------------------------------------------------------------------+ | = 本文為Haohappy讀<
n"); } //FALSE if($w1->equals($w3)) { print("w1 and w3 are the same
n"); } //FALSE, == includes id in comparison if($w1 == $w2) //不等,因為ID不同 { print("w1 and w2 are the same
n"); } ?> 如果你對面向對象編程不熟悉,你可能想知道用private成員的目的是什麼. 你可以回憶一下封裝和耦合的想法,這在本章開頭我們有討論過. Private成員有助於封裝數據. 他們可以隱藏在一個類內部而不被類外部的代碼接觸到. 同時他們還有助於實現松散的耦合. 如果數據結構外的代碼不能直接訪問內部屬性,那麼就不會產生一個隱性的關聯性. 當然,大部分private屬性仍然可以被外部代碼共享. 解決方法是用一對public方法,一個是get(獲取屬性的值),另一個是set(設置屬性的值). 構造函數也接受屬性的初始值. 這使得成員間的交流通過一個狹窄的,經過良好限定的接口來進行. 這也提供改變傳遞給方法的值的機會. 注意在例子6.8中,構造函數如何強制使price成為一個float數(floadval()). Protected(受保護的) 成員能被同個類中的所有方法和繼承出的類的中所有方法訪問到. Public屬性有違封裝的精神,因為它們允許子類依賴於一個特定的屬性來書寫.protected方法則不會帶來這方面的擔憂.一個使用protected方法的子類需要很清楚它的父類的結構才行. 例子6.9由例子6.8改進而得到,包含了一個Widget的子類Thing. 注意Widget現在有一個叫作getName的protected方法. 如果Widget的實例試圖調用protected方法將會出錯: $w1->getName()產生了一個錯誤. 但子類Thing中的getName方法可以調用這個protected方法.當然對於證明Widget::getName方法是protected,這個例子顯得過於簡單. 在實際情況下,使用protected方法要依賴於對對象的內部結構的理解. Listing 6.9 Protected members name = $name; $this->price = floatval($price); $this->id = uniqid(); } //checks if two widgets are the same public function equals($widget) { return(($this->name == $widget->name)AND ($this->price == $widget->price)); } protected function getName() { return($this->name); } } class Thing extends Widget { private $color; public function setColor($color) { $this->color = $color; } public function getColor() { return($this->color); } public function getName() { return(parent::getName()); } } $w1 = new Widget(Cog, 5.00); $w2 = new Thing(Cog, 5.00); $w2->setColor(Yellow); //TRUE (still!) 結果仍然為真 if($w1->equals($w2)) { print("w1 and w2 are the same
n"); } //print Cog 輸出 Cog print($w2->getName()); ?> 一個子類可能改變通過覆寫父類方法來改變方法的訪問方式,盡管如此,仍然有一些限制. 如果你覆寫了一個public類成員,他子類中必須保持public. 如果你覆寫了一個protected成員,它可保持protected或變成public.Private成員仍然只在當前類中可見. 聲明一個與父類的private成員同名的成員將簡單地在當前類中建立一個與原來不同的成員. 因此,在技術上你不能覆寫一個private成員. Final關鍵字是限制訪問成員方法的另一個方法. 子類不能覆寫父類中標識為final的方法. Final關鍵字不能用於屬性. //haohappy注:PHP5的面向對象模型仍然不夠完善,如final不像Java中那樣對Data,Method甚至Class都可以用.