php重載方法
Ⅰ php和c,c++的區別是什麼
的區別:
一個有protected成員變數(假設為i)的類型Base,他的子類Derived直接繼承自Base,同時Derived有一個成員函數func,他的參數是Base類型的,這個函數可以訪問Base對象的protecte的成員嗎?在C++中不可以,而在PHP中可以。
關於重載:
PHP中不支持C++中的重載,重新定義個函數(不管是參數相同還是不同,都會導致重復定義錯誤)。PHP有自己的重載方法,而且比C++中的更廣泛,他不僅可以重載函數(通過使運散用__call()方法),還可以重載成員變數(通過使用__get()和__set())。而C++中只能對函數進行重載,而且重載的方法只有:不同的參數類型,不同的函數修飾符(const)。
關於abstract和interface
PHP中配悄余有這兩個修飾符,因為PHP不支持對一個普通類的多繼承,因此interface用於實現多繼承。Abstract類在C++中也存在,只是實現方培滾式不一樣,C++中使用pure virtual函數來表明這個類是抽象類,不能單獨被實例化。而PHP中不僅可以使用函數的修飾符abstract(另外class前也必須標明abstract)來標明這個意思,也可以只使用abstract修飾符修飾class更直接的表明他是抽象類。另外, C++中的pure virtual函數不受訪問類型的限制,不管是什麼訪問類型,都會被看作是public;而php中的abstract函數不能被聲明成private,僅此而已。
多態
因為PHP是弱類型語言,所以他的多態性到處都有體現,導致他的多態性不像C++中那麼明顯。比如,在PHP中基類的函數可以看作全是virtual的,因此它不需要加任何修飾符,子類中和基類同名的函數都會被動態調用,而C++不一樣,如果基類中的這個函數沒有加virtual修飾符,子類中的那個同名函數就不會被動態調用,只能靜態調用了。
操作符重載
PHP中不存在,而C++存在。重點在==操作符,在PHP中他可以運用在任何類型上,即使這個類型沒有(像C++中一樣)寫自己的==重載函數。PHP中對於對象的比較,==表示兩個對象的屬性和值都一樣,而且類型也一樣;PHP也存在一個===操作符,表示他們引用了同一個對象,這跟java中很像吧。
final關鍵字
PHP中存在這個關鍵字,表示這個函數不能被重寫(如果他用來修飾函數),或者類不能被繼承(如果用類修飾class)。而C++中沒有這個關鍵字,也無法模擬出那個效果。
對象賦值和拷貝
C++中的拷貝或者賦值大致有這三種方式。
一種是指針的賦值,即p1 = &obj,相當於PHP和java中的賦值操作;
另一種是memberwise assignment,也就是在obj1 = obj2時發生的事情,默認情況下執行淺度拷貝,和PHP中clone的效果一樣。他可以通過重載賦值拷貝操作來執行你的深度拷貝或者其他自定義的拷貝,這就相當於PHP中的__clone()成員函數;
第三種是memberwise initialization,也就是在參數傳遞時,傳遞返回值時或者包含對象的容器初始化的時候自動運行的,你可以通過自己定義拷貝構造函數來控制它的效果。
拷貝構造函數在PHP中幾乎用不到,因為他的傳遞是完全按引用傳遞,而不是對象的直接拷貝。
Ⅱ php中如何實現函數重載呢
PHP本身不能函數重載的,不過你可以使用類中的__call的魔術方法來實現。該魔術方法接受兩個參數,一個數方法的名稱,一個是包含該方法參數的數組。當對一個類調用一個不可見的方法時(比如該方法是private或者根本沒有這個方法)被觸發調用。
Ⅲ php怎麼方法重載
php面向對象(OOP)編程完全教程:12.重載新的方法
在學習PHP 這種語言中你會發現, PHP中的方法是不能重載的, 所謂的方法重載就是定義相同的方法名,通過「參數的個數「不同或「參數的類型「不同,來訪問我們的相同方法名的不同方法。但是因為PHP是弱類型的語言, 所以在方法的參數中本身就可以接收不同類型的數據,又因為PHP的方法可以接收不定個數的參數,所以通過傳遞不同個數的參數調用不相同方法名的不同方法也是不成立的。所以在PHP裡面沒有方法重載。不能重載也就是在你的項目中不能定義相同方法名的方法。另外,因為PHP沒有名子空間的概念,在同一個頁面和被包含的頁面中不能定義相同名稱的方法, 也不能定義和PHP給我提供的方法的方法重名,當然在同一個類中也不能定義相同名稱的方法。
我們這里所指的重載新的方法所指的是什麼呢?其實我們所說的重載新的方法就是子類覆蓋父類的已有的方法,那為什麼要這么做呢?父類的方法不是可以繼承過來直接用嗎?但有一些情況是我們必須要覆蓋的,比如說我們前面提到過的例子裡面, 「Person」這個人類裡面有一個「說話」的方法,所有繼承「Person」類的子類都是可以「說話」的, 我們「Student」類就是「Person」類的子類,所以「Student」的實例就可以「說話「了, 但是人類裡面「說話」的方法裡面說出的是「Person」類裡面的屬性, 而「Student」類對「Person」類進行了擴展,又擴展出了幾個新的屬性,如果使用繼承過來的「say()」說話方法的話,只能說出從「Person」類繼承過來的那些屬性,那麼新擴展的那些屬性使用這個繼承過來的「say()」的方法就說不出來了,那有的人就問了,我在「Student」這個子類中再定義一個新的方法用於說話,說出子類裡面所有的屬性不就行了嗎?一定不要這么做, 從抽象的角度來講, 一個「學生」不能有兩種「說話」的方法,就算你定義了兩個不同的說話的方法,可以實現你想要的功能,被繼承過來的那個「說話「方法可能沒有機會用到了,而且是繼承過來的你也刪不掉。這個時候我們就要用到覆蓋了。
雖然說在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 "我的名子叫:".$this->name." 性別:".$this->sex." 我的年齡是:".$this->age;
}
}
class Student extends Person
{
var $school; //學生所在學校的屬性
//這個學生學習的方法
function study()
{
echo "我的名子叫:".$this->name." 我正在".$this->school." 學習";
}
//這個學性可以說話的方法, 說出自己所有的屬性,覆蓋了父類的同名方法
function say()
{
echo "我的名子叫:".$this->name." 性別:".$this->sex." 我的年齡是:".$this->age."我在".$this->school."上學;
}
}
?>
上面的例子, 我們就在「Student」子類里覆蓋了繼承父類裡面的」say()」的方法,通過覆蓋我們就實現了對「方法」擴展。
但是,像這樣做雖然解決了我們上面說的問題,但是在實際開發中,一個方法不可能就一條代碼或是幾條代碼,比如說「Person」類裡面的「say()」方法有裡面有100條代碼,如果我們想對這個方法覆蓋保留原有的功能外加上一點點功能,就要把原有的100條代碼重寫一次, 再加上擴展的幾條代碼,這還算是好的,而有的情況,父類中的方法是看不見原代碼的,這個時候你怎麼去重寫原有的代碼呢?我們也有解決的辦法,就是在子類這個方法中可以調用到父類中被覆蓋的方法, 也就是把被覆蓋的方法原有的功能拿過來再加上自己的一點功能,可以通過兩種方法實現在子類的方法中調用父類被覆蓋的方法:
一種是使用父類的「類名::「來調用父類中被覆蓋的方法;
一種是使用「parent::」的方試來調用父類中被覆蓋的方法;
代碼
class Student extends Person
{
var $school; //學生所在學校的屬性
//這個學生學習的方法
function study()
{
echo "我的名子叫:".$this->name." 我正在".$this->school." 學習";
}
//這個學性可以說話的方法, 說出自己所有的屬性,覆蓋了父類的同名方法
function say()
{
//使用父類的"類名::"來調用父類中被覆蓋的方法;
// Person::say();
//或者使用"parent::"的方試來調用父類中被覆蓋的方法;
parent::say();
//加上一點自己的功能
echo "我的年齡是:".$this->age."我在".$this->school."上學.";
}
}
現在用兩種方式都可以訪問到父類中被覆蓋的方法,我們選那種方式最好呢?用戶可能會發現自己寫的代碼訪問了父類的變數和函數。如果子類非常精煉或者父類非常專業化的時候尤其是這樣。 不要用代碼中父類文字上的名字,應該用特殊的名字 parent,它指的就是子類在 extends 聲明中所指的父類的名字。這樣做可以避免在多個地方使用父類的名字。如果繼承樹在實現的過程中要修改,只要簡單地修改類中 extends 聲明的部分。
同樣,構造方法在子類中如果沒有聲明的話,也可以使用父類中的構造方法,如果子類中重新定義了一個構造方法也會覆蓋掉父類中的構造方法,如果想使用新的構造方法為所有屬性賦值也可以用同樣的方式。
代碼
class Student extends Person
{
var $school; //學生所在學校的屬性
function __construct($name, $sex, $age, $school)
{
//使用父類中的方法為原有的屬性賦值
parent::__construct($name, $sex, $age);
$this->school=$school;
}
//這個學生學習的方法
function study()
{
echo "我的名子叫:".$this->name." 我正在".$this->school." 學習";
}
//這個人可以說話的方法, 說出自己的屬性
function say()
{
parent::say();
//加上一點自己的功能
echo "我的年齡是:".$this->age."我在".$this->school."上學.";
}
}
Ⅳ PHP中 重載函數 __get() __set() _call作用及參數是什麼
void __set ( string $name , mixed $value )
__set在對類內不可訪問的成員賦值時被調用,$name是成員名,$value是賦的值
mixed __get ( string $name )
__get在對內類內不可訪問的成員取值時被調用,$name是成員名
mixed __call ( string $name , array $arguments )
__call在對類內不可訪問的方法調用時被調用,$name是方法名,$arguments是調用這個方法提供的參數
Ⅳ PHP重載 有什麼用
用到的情況還是很多的 比方說 你在做底層開發時 經常會創建一些共有的 變數 就要載入這些數據 這是就得用這些函數了
Ⅵ PHP重載到底是什麼意思
針對不同參數形式寫出的多個功能類似名字一樣的函槐碧數。
比如
sort(int a,int b){}
sort(double c,double d,double f){}
這兩鉛卜舉個函數就是重載關系。表示了弊或功能類似名字一樣的兩個函數,只是參數形式不一樣
Ⅶ php如何使用數組語法訪問的重載!
問題
1.ArrayAccess 這個名字好像不能用,不太清楚問什麼,
2.介面中的返回值,應該是不用學的,php返回值是自動的。寫上會報錯的。
3.function offsetSet($name) 的參數和介面的對應不上
4.$userMap 是類對象,而此處$userMap["John"]; 用數組形式調用,
以下是調整後的,另外附帶一個 簡單的類及介面。
/*
interface Shop
{
public function buy($gid);
public function sell($gid);
public function view($gid);
}
class BaseShop implements Shop
{
public function buy($gid)
{
echo('你購買了ID為 :'.$gid.'的商品');
}
public function sell($gid)
{
echo('你賣了ID為 :'.$gid.'的商品');
}
public function view($gid)
{
echo('你查看了ID為 :'.$gid.'的商品');
}
}
*/
interface Access
{
public function offsetExists($index);
public function offsetGet($index);
public function offsetSet($index,$new_value);
public function offsetUnset($index);
}
class UserToSocialSecurity implements Access
{
private $db;
public function offsetExists($name){
return $this->db->userExists($name);
}
public function offsetGet($name){
return $this->db->getUserId($name);
}
public function offsetSet($name,$id){
return $this->db->setUserId($name,$id);
}
public function offsetUnset($name){
return $this->db->removeUser($name);
}
}
Ⅷ PHP構造器是不是不能重載 - PHP進階討論
原帖由 於 2008-9-28 09:53 發表 [i][/url]重載:(overload)1.在同一個類中;(不單單是類中,普通函數也包括)2.方法名相同;3.參數個數或者參數類型不同(如果參數類型和個數相同,但是類型順序不同也是重載!)4.與返回類型無關勞倫斯兄弟說得對,PH ... [/b]龍兄說對了關鍵的概念沒弄清楚吧,名詞與用途沒有對上號。1、弄清概念:重載(overload)、重寫(override)、繼承(extends)2、PHP是弱類型,重載根據變數類型和個數不同而進行,所以只能模擬重載。3、PHP支持在繼承類中重寫(覆蓋)方法。4、構造函數(_construct)可以被繼承。
Ⅸ php 有方法重載嗎
直接重載是無法實現的.但是可以通過__call()方法來變相實現.實際上這個方法是PHP開發者偷懶,才想出這么一個拐彎抹角的方法,而且用這個方法實現的重載程度非常有限,尤其是構造器重載,已經不是真正意義上的構造器。構造器在對象被創建時自動執行,一般不會顯式的調用。而用__call()方法實現的構造器必須顯示的調用,也就是說構造函數與普通函數的性質完全相同,只不過功能不同而已了。
http://www.nowamagic.net/php/php_Override.php