本文實(shí)例講述了PHP面向?qū)ο?/a>程序設(shè)計(jì)(OOP)之方法重寫(override)操作。分享給大家供大家參考,具體如下:
因?yàn)镻HP是弱類型的語言, 所以在方法的參數(shù)中本身就可以接收不同類型的數(shù)據(jù),又因?yàn)镻HP的方法可以接收不定個(gè)數(shù)的參數(shù),所以通過傳遞不同個(gè)數(shù)的參數(shù)調(diào)用不相同方法名的不同方法也是不成立的,所以php是不能重載的。
雖然說在PHP里面不能定義同名的方法, 但是在父子關(guān)系的兩個(gè)類中,我們可以在子類中定義和父類同名的方法,這樣就把父類中繼承過來的方法覆蓋掉了(重寫父類方法)。
<?php class Person { //下面是人的成員屬性 var $name; //人的名子 var $sex; //人的性別 var $age; //人的年齡 //定義一個(gè)構(gòu)造方法參數(shù)為屬性姓名$name、性別$sex和年齡$age進(jìn)行賦值 function __construct($name, $sex, $age) { $this->name = $name; $this->sex = $sex; $this->age = $age; } //這個(gè)人可以說話的方法, 說出自己的屬性 function say() { echo "my name is:" . $this->name . " sex:" . $this->sex . " my age is:" . $this->age; } } //定義一個(gè)子類“學(xué)生類“使用”extends”關(guān)鍵字來繼承”人”類: class Student extends Person { var $school; //學(xué)生所在學(xué)校的屬性 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; } //這個(gè)學(xué)生學(xué)習(xí)的方法 function study() { echo "my name is:" . $this->name . " my school is:" . $this->school; } } ?>
另外在子類覆蓋父類的方法時(shí)也要注意一點(diǎn),子類中方法的訪問權(quán)限一定不能低于父類被覆蓋方法的訪問權(quán)限,也就是一定要高于或等于父類方法的訪問權(quán)限。
例如,如果父類方法的訪問權(quán)限是protected
,那么子類中要覆蓋的權(quán)限就要是protected
和public
,如果父類的方法是public那么子類中要覆蓋的方法只能也是public
,總之子類中的方法總是要高于或等于父類被覆蓋方法的訪問權(quán)限。
上面的例子, 我們就在“Student”子類里覆蓋了繼承父類里面的”say()”的方法,通過覆蓋我們就實(shí)現(xiàn)了對(duì)“方法”擴(kuò)展。但是,像這樣 做雖然解決了我們上面說的問題,但是在實(shí)際開發(fā)中,一個(gè)方法不可能就一條代碼或是幾條代碼,比如說“Person”類里面的“say()”方法有里面有 100條代碼,如果我們想對(duì)這個(gè)方法覆蓋保留原有的功能外加上一點(diǎn)點(diǎn)功能,就要把原有的100條代碼重寫一次, 再加上擴(kuò)展的幾條代碼,這還算是好的,而有的情況,父類中的方法是看不見原代碼的,這個(gè)時(shí)候你怎么去重寫原有的代碼呢?我們也有解決的辦法,就是在子類這 個(gè)方法中可以調(diào)用到父類中被覆蓋的方法, 也就是把被覆蓋的方法原有的功能拿過來再加上自己的一點(diǎn)功能,可以通過兩種方法實(shí)現(xiàn)在子類的方法中調(diào)用父類被覆蓋的方法:
-
一種是使用父類的“
類名::
“來調(diào)用父類中被覆蓋的方法; -
一種是使用“
parent::
”的方試來調(diào)用父類中被覆蓋的方法;
//定義一個(gè)子類“學(xué)生類“使用”extends”關(guān)鍵字來繼承”人”類: class Student extends Person { var $school; //學(xué)生所在學(xué)校的屬性 function __construct($name,$sex,$age,$school) { parent::__construct($name,$sex,$age); $this->school = $school; } // 重寫父類的say()方法 function say() { //使用父類的"類名::"來調(diào)用父類中被覆蓋的方法; // Person::say(); //或者使用"parent::"的方試來調(diào)用父類中被覆蓋的方法; parent::say(); echo "my name is:" . $this->name ." my school is:" . $this->school; } //這個(gè)學(xué)生學(xué)習(xí)的方法 function study() { echo "my name is:" . $this->name . " my school is:" . $this->school; } }
現(xiàn)在用兩種方式都可以訪問到父類中被覆蓋的方法,我們選那種方式最好呢?用戶可能會(huì)發(fā)現(xiàn)自己寫的代碼訪問了父類的變量和函數(shù)。如果子類非常精煉或者父類非 常專業(yè)化的時(shí)候尤其是這樣。 不要用代碼中父類文字上的名字,應(yīng)該用特殊的名字 parent
,它指的就是子類在 extends
聲明中所指的父類的名字。這樣做可以避免在多個(gè)地方使用父類的名字。如果繼承樹在實(shí)現(xiàn)的過程中要修改,只要簡(jiǎn)單地修改類中 extends
聲明的部分。
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。