方法的重载【转】
如果從父類繼承的方法不能滿足子類的需求,可以對其進行改寫,這個過程叫方法的覆蓋(override),也稱為方法的重載。
當對父類的方法進行重寫時,子類中的方法必須和父類中對應的方法具有相同的方法名稱,在PHP5中不限制輸入參數類型、參數數量和返回值類型。(這點和Java不同)。
子類中的覆蓋方法不能使用比父類中被覆蓋方法更嚴格的訪問權限。
聲明方法時,如果不定義訪問權限。默認權限為public。
PHP5重寫方法
先設置一個父類,這個父類是 “Dog”類,這個類描述了dog的特性。
Dog有2個眼睛,會跑,會叫。就這樣描述先。
我養了一直狗,是只小狗,符合Dog類的特性,但有所不同。
我的小狗有名字,我的小狗太小了,不會大聲的叫,只會哼哼。
我們用繼承的概念去實現這個設計。
1 <? 2 // 狗有兩只眼睛,會汪汪叫,會跑. 3 class Dog { 4 protected $eyeNumber =2; //屬性 5 //返回封裝屬性的方法. 6 public function getEyeNumber(){ 7 return $this->eyeNumber; 8 } 9 //狗會叫 10 public function yaff(){ 11 return "Dog yaff, wang ..wang .."; 12 } 13 //狗會跑 14 public function run(){ 15 return "Dog run..running ..."; 16 } 17 } 18 $dog = new Dog(); 19 echo "dog have ".$dog->getEyeNumber()." eyes. <br>"; 20 echo $dog->yaff() ."<br>".$dog->run(); 21 echo "<br><br>"; 22 //這是我的小狗叫"狗狗",它很小.不會汪汪叫,只會哼哼哼.. 23 class MyDog extends Dog { 24 private $name = "狗狗"; 25 public function getName(){ 26 return $this->name; 27 } 28 public function yaff(){ 29 return $this->name." yaff, heng...heng .."; 30 } 31 } 32 $myDog = new MyDog(); 33 echo $myDog->getName()." have ".$myDog->getEyeNumber()." eyes. <br>"; 34 echo $myDog->yaff() ."<br>".$myDog->run(); 35 ?>?
程序運行結果:
dog have 2 eyes. Dog yaff, wang ..wang .. Dog run..running ... 狗狗 have 2 eyes. 狗狗 yaff, heng...heng .. Dog run..running ...?
重寫方法與訪問權限
子類中的覆蓋方法不能使用比父類中被覆蓋方法更嚴格的訪問權限。
父類為public 子類為 private時。
1 <? 2 // 簡化dog類和mydog類,演示重寫的訪問權限. 3 class Dog { 4 protected $eyeNumber =2; //屬性 5 //返回封裝屬性的方法. 6 public function getEyeNumber(){ 7 return $this->eyeNumber; 8 } 9 } 10 class MyDog extends Dog { 11 protected function getEyeNumber(){ 12 return $this->eyeNumber; 13 } 14 } 15 /* 16 class MyDog extends Dog { 17 private function getEyeNumber(){ 18 return $this->eyeNumber; 19 } 20 } 21 */ 22 ?>?
程序運行結果:
Fatal error: Access level to MyDog::getEyeNumber() must be public (as in class Dog) in E:\PHPProjects\test.php on line *父類為public 子類為 protected時。
<? // 簡化dog類和mydog類,演示重寫的訪問權限. class Dog {protected $eyeNumber =2; //屬性//返回封裝屬性的方法.public function getEyeNumber(){ return $this->eyeNumber;} } class MyDog extends Dog {private function getEyeNumber(){ return $this->eyeNumber;} } ?>?
程序運行結果:
Fatal error: Access level to MyDog::getEyeNumber() must be public (as in class Dog) in E:\PHPProjects\test.php on line *重寫時的參數數量
子類可以擁有與父類不同的參數數量。(這點與java不同,PHP是弱類型語言。)
1 <? 2 // 簡化dog類和mydog類,演示重寫方法的參數. 3 class Dog { 4 protected $eyeNumber =2; //屬性 5 //返回封裝屬性的方法. 6 public function getEyeNumber(){ 7 return $this->eyeNumber; 8 } 9 } 10 class MyDog extends Dog { 11 //重寫的方法與父類的方法有不同的參數數量. 12 public function getEyeNumber($eys){ 13 $this->eyeNumber = $eys; 14 return $this->eyeNumber; 15 } 16 } 17 $myDog = new MyDog(); 18 echo "my dog hava ".$myDog->getEyeNumber(3) ." eyes."; 19 //嘯天犬..哈.. 20 //下面這句會報一個丟失參數的錯誤. 21 //echo "my dog hava ".$myDog->getEyeNumber() ." eyes."; 22 ?>?
程序運行結果:
1 my dog hava 3 eyes. 構造函數重寫下面這個例子中,父類和子類都有自己的構造函數,當子類被實例化時,子類的構造函數被調用,而父類的構造函數沒有被調用,請對比第一節的構造函數繼承。
1 <? 2 //2-2 / extends1.php 3 //構造函數繼承的問題. 4 class Animal{ 5 public $legNum = 0; 6 public function __construct(){ 7 $this->legNum = 4; 8 echo "I am an animal<br>"; 9 } 10 } 11 class Dog1 extends Animal { 12 public function __construct(){ 13 $this->legNum = 4; 14 echo "I am a Dog .<br>"; 15 } 16 } 17 $dog1 = new Dog1(); 18 echo "<br>"; 19 echo "legNum is ".$dog1->legNum; 20 /* 21 實例化子類時.構造函數被調用了. 22 */ 23 ?>?
程序運行結果:
1 I am a Dog . 2 legNum is 4?
注:這點和Java不同,在java中構造函數是不能被繼承的,而且子類實例化時,子類的構造函數被調用,父類的構造函數也會調用。
原文地址
轉載于:https://www.cnblogs.com/soongkun/p/4274968.html
總結
- 上一篇: FileUpload控件
- 下一篇: POJ1269:Intersecting