這篇文章主要介紹了PHP面向對象程序設計(OOP)之方法重寫(override)操作,簡單描述了php面向對象程序設計中方法重寫的原理,並結合實例形式分析了php方法重寫相關實現技巧與注意事項,需要的朋友可以參考下
本文實例講述了PHP面向對象程序設計(OOP)之方法重寫(override)操作。分享給大家供大家參考,具體如下:
因爲PHP是弱類型的語言, 所以在方法的參數中本身就可以接收不同類型的數據,又因爲PHP的方法可以接收不定個數的參數,所以通過傳遞不同個數的參數調用不相同方法名的不同方法也是不成立的,所以php是不能重載的。
雖然說在PHP裏面不能定義同名的方法, 但是在父子關係的兩個類中,我們可以在子類中定義和父類同名的方法,這樣就把父類中繼承過來的方法覆蓋掉了(重寫父類方法)。
<?php class Person { //下面是人的成員屬性 var $name; //人的名子 var $sex; //人的性別 var $age; //人的年齡 //定義一個構造方法參數爲屬性姓名$name、性別$sex和年齡$age進行賦值 function __construct($name, $sex, $age) { $this->name = $name; $this->sex = $sex; $this->age = $age; } //這個人可以說話的方法, 說出自己的屬性 function say() { echo "my name is:" . $this->name . " sex:" . $this->sex . " my age is:" . $this->age; } } //定義一個子類“學生類“使用”extends”關鍵字來繼承”人”類: class Student extends Person { var $school; //學生所在學校的屬性 function __construct($name,$sex,$age,$school) { parent::__construct($name,$sex,$age); $this->school = $school; } // 重寫父類的say()方法 function say() { echo "my name is:" . $this->name ." my school is:" . $this->school; } //這個學生學習的方法 function study() { echo "my name is:" . $this->name . " my school is:" . $this->school; } } ?>
另外在子類覆蓋父類的方法時也要注意一點,子類中方法的訪問權限一定不能低於父類被覆蓋方法的訪問權限,也就是一定要高於或等於父類方法的訪問權限。
例如,如果父類方法的訪問權限是protected
,那麼子類中要覆蓋的權限就要是protected
和public
,如果父類的方法是public那麼子類中要覆蓋的方法只能也是public
,總之子類中的方法總是要高於或等於父類被覆蓋方法的訪問權限。
上面的例子, 我們就在“Student”子類裏覆蓋了繼承父類裏面的”say()”的方法,通過覆蓋我們就實現了對“方法”擴展。但是,像這樣 做雖然解決了我們上面說的問題,但是在實際開發中,一個方法不可能就一條代碼或是幾條代碼,比如說“Person”類裏面的“say()”方法有裏面有 100條代碼,如果我們想對這個方法覆蓋保留原有的功能外加上一點點功能,就要把原有的100條代碼重寫一次, 再加上擴展的幾條代碼,這還算是好的,而有的情況,父類中的方法是看不見原代碼的,這個時候你怎麼去重寫原有的代碼呢?我們也有解決的辦法,就是在子類這 個方法中可以調用到父類中被覆蓋的方法, 也就是把被覆蓋的方法原有的功能拿過來再加上自己的一點功能,可以通過兩種方法實現在子類的方法中調用父類被覆蓋的方法:
- 一種是使用父類的“
類名::
“來調用父類中被覆蓋的方法; - 一種是使用“
parent::
”的方試來調用父類中被覆蓋的方法;
//定義一個子類“學生類“使用”extends”關鍵字來繼承”人”類: class Student extends Person { var $school; //學生所在學校的屬性 function __construct($name,$sex,$age,$school) { parent::__construct($name,$sex,$age); $this->school = $school; } // 重寫父類的say()方法 function say() { //使用父類的"類名::"來調用父類中被覆蓋的方法; // Person::say(); //或者使用"parent::"的方試來調用父類中被覆蓋的方法; parent::say(); echo "my name is:" . $this->name ." my school is:" . $this->school; } //這個學生學習的方法 function study() { echo "my name is:" . $this->name . " my school is:" . $this->school; } }
現在用兩種方式都可以訪問到父類中被覆蓋的方法,我們選那種方式最好呢?用戶可能會發現自己寫的代碼訪問了父類的變量和函數。如果子類非常精煉或者父類非 常專業化的時候尤其是這樣。 不要用代碼中父類文字上的名字,應該用特殊的名字 parent
,它指的就是子類在 extends
聲明中所指的父類的名字。這樣做可以避免在多個地方使用父類的名字。如果繼承樹在實現的過程中要修改,只要簡單地修改類中 extends
聲明的部分。
更多關於PHP相關內容感興趣的讀者可查看本站專題:《php面向對象程序設計入門教程》、《PHP數組(Array)操作技巧大全》、《PHP基本語法入門教程》、《PHP運算與運算符用法總結》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧彙總》
希望本文所述對大家PHP程序設計有所幫助。