本文實(shí)例講述了PHP面向?qū)ο蟪绦蛟O(shè)計(jì)(OOP)之方法重寫(xiě)(override)操作。分享給大家供大家參考,具體如下:
因?yàn)镻HP是弱類(lèi)型的語(yǔ)言, 所以在方法的參數(shù)中本身就可以接收不同類(lèi)型的數(shù)據(jù),又因?yàn)镻HP的方法可以接收不定個(gè)數(shù)的參數(shù),所以通過(guò)傳遞不同個(gè)數(shù)的參數(shù)調(diào)用不相同方法名的不同方法也是不成立的,所以php是不能重載的。
雖然說(shuō)在PHP里面不能定義同名的方法, 但是在父子關(guān)系的兩個(gè)類(lèi)中,我們可以在子類(lèi)中定義和父類(lèi)同名的方法,這樣就把父類(lèi)中繼承過(guò)來(lái)的方法覆蓋掉了(重寫(xiě)父類(lèi)方法)。
?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è)人可以說(shuō)話的方法, 說(shuō)出自己的屬性
function say() {
echo "my name is:" . $this->name . " sex:" . $this->sex . " my age is:" . $this->age;
}
}
//定義一個(gè)子類(lèi)“學(xué)生類(lèi)“使用”extends”關(guān)鍵字來(lái)繼承”人”類(lèi):
class Student extends Person
{
var $school; //學(xué)生所在學(xué)校的屬性
function __construct($name,$sex,$age,$school)
{
parent::__construct($name,$sex,$age);
$this->school = $school;
}
// 重寫(xiě)父類(lèi)的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;
}
}
?>
另外在子類(lèi)覆蓋父類(lèi)的方法時(shí)也要注意一點(diǎn),子類(lèi)中方法的訪問(wèn)權(quán)限一定不能低于父類(lèi)被覆蓋方法的訪問(wèn)權(quán)限,也就是一定要高于或等于父類(lèi)方法的訪問(wèn)權(quán)限。
例如,如果父類(lèi)方法的訪問(wèn)權(quán)限是protected
,那么子類(lèi)中要覆蓋的權(quán)限就要是protected
和public
,如果父類(lèi)的方法是public那么子類(lèi)中要覆蓋的方法只能也是public
,總之子類(lèi)中的方法總是要高于或等于父類(lèi)被覆蓋方法的訪問(wèn)權(quán)限。
上面的例子, 我們就在“Student”子類(lèi)里覆蓋了繼承父類(lèi)里面的”say()”的方法,通過(guò)覆蓋我們就實(shí)現(xiàn)了對(duì)“方法”擴(kuò)展。但是,像這樣 做雖然解決了我們上面說(shuō)的問(wèn)題,但是在實(shí)際開(kāi)發(fā)中,一個(gè)方法不可能就一條代碼或是幾條代碼,比如說(shuō)“Person”類(lèi)里面的“say()”方法有里面有 100條代碼,如果我們想對(duì)這個(gè)方法覆蓋保留原有的功能外加上一點(diǎn)點(diǎn)功能,就要把原有的100條代碼重寫(xiě)一次, 再加上擴(kuò)展的幾條代碼,這還算是好的,而有的情況,父類(lèi)中的方法是看不見(jiàn)原代碼的,這個(gè)時(shí)候你怎么去重寫(xiě)原有的代碼呢?我們也有解決的辦法,就是在子類(lèi)這 個(gè)方法中可以調(diào)用到父類(lèi)中被覆蓋的方法, 也就是把被覆蓋的方法原有的功能拿過(guò)來(lái)再加上自己的一點(diǎn)功能,可以通過(guò)兩種方法實(shí)現(xiàn)在子類(lèi)的方法中調(diào)用父類(lèi)被覆蓋的方法:
- 一種是使用父類(lèi)的“
類(lèi)名::
“來(lái)調(diào)用父類(lèi)中被覆蓋的方法;
- 一種是使用“
parent::
”的方試來(lái)調(diào)用父類(lèi)中被覆蓋的方法;
//定義一個(gè)子類(lèi)“學(xué)生類(lèi)“使用”extends”關(guān)鍵字來(lái)繼承”人”類(lèi):
class Student extends Person
{
var $school; //學(xué)生所在學(xué)校的屬性
function __construct($name,$sex,$age,$school)
{
parent::__construct($name,$sex,$age);
$this->school = $school;
}
// 重寫(xiě)父類(lèi)的say()方法
function say()
{
//使用父類(lèi)的"類(lèi)名::"來(lái)調(diào)用父類(lèi)中被覆蓋的方法;
// Person::say();
//或者使用"parent::"的方試來(lái)調(diào)用父類(lèi)中被覆蓋的方法;
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)在用兩種方式都可以訪問(wèn)到父類(lèi)中被覆蓋的方法,我們選那種方式最好呢?用戶可能會(huì)發(fā)現(xiàn)自己寫(xiě)的代碼訪問(wèn)了父類(lèi)的變量和函數(shù)。如果子類(lèi)非常精煉或者父類(lèi)非 常專業(yè)化的時(shí)候尤其是這樣。 不要用代碼中父類(lèi)文字上的名字,應(yīng)該用特殊的名字 parent
,它指的就是子類(lèi)在 extends
聲明中所指的父類(lèi)的名字。這樣做可以避免在多個(gè)地方使用父類(lèi)的名字。如果繼承樹(shù)在實(shí)現(xiàn)的過(guò)程中要修改,只要簡(jiǎn)單地修改類(lèi)中 extends
聲明的部分。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語(yǔ)法入門(mén)教程》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- php中__toString()方法用法示例
- php面向?qū)ο笕ヂ?(十一)__toString()用法 克隆對(duì)象 __call處理調(diào)用錯(cuò)誤
- PHP 5.3新增魔術(shù)方法__invoke概述
- php面向?qū)ο蟪绦蛟O(shè)計(jì)中self與static的區(qū)別分析
- PHP面向?qū)ο笾衝ew self()與 new static()的區(qū)別淺析
- php面向?qū)ο笾衧tatic靜態(tài)屬性和靜態(tài)方法的調(diào)用
- PHP 面向?qū)ο?final類(lèi)與final方法
- PHP面向?qū)ο笾?深入理解static變量與方法
- php面向?qū)ο笾衧tatic靜態(tài)屬性與方法的內(nèi)存位置分析
- PHP面向?qū)ο缶幊讨钊肜斫夥椒ㄖ剌d與方法覆蓋(多態(tài))
- PHP面向?qū)ο蟪绦蛟O(shè)計(jì)__tostring()和__invoke()用法分析