首頁 > php教程 > PHP开发 > 主體

php物件導向的方法重載兩種版本比較

黄舟
發布: 2016-12-14 11:57:21
原創
1105 人瀏覽過

多個函數用同一個名字,但參數表,即參數的個數或(和)資料型別可以不同,呼叫的時候,雖然方法名字相同,但根據參數表可以自動呼叫對應的函數。
PHP4 中僅僅實現了物件導向的部分的、簡單的功能,而 PHP5 以後對物件的支援就強大的多了。
對於多態的實現,PHP4 只支援覆蓋(override),而不支援重載(overload)。但我們可以透過一些技巧來「模擬」重載的實現。
PHP5 雖然可以支援覆蓋和重載,但重載在具體實作上,和其他語言還有較大的差異。
1,在PHP4 中「模擬」重載

試看以下程式碼:

//根據參數個數選擇執行不同的方法(在PHP4 模擬"重載"(多態性的一種)

class Myclass 

function Myclass() 

$method = "method" . func_num_args(); 
$this->$method(); 
}

function method1($x) 

echo " method1"; 
}

function method2($x, $y) 

echo 'method2'; 

}

//透過在類別中的額外使用,
$obj1 = new Myclass('A'); //將呼叫method1 
$obj2 = new Myclass('B','C'); //將呼叫method2 
?>

以上程式碼中,透過建構在建構函式中使用func_num_args() 函式取到參數的個數,自動執行method1 或method2 方法。

先看以下範例:

複製程式碼如下:

class Myclass 

public $attriable; 
public $one = "this is one"; 
.

function __construct() 
{ }


function one($one) 

$this->one=$one; 

}$this->attriable; $one, $two) 

$this->one=$one; 
$this->two=$two; 
$this->attriable = $this->one . $this->two 

}


function display() 

echo $this->attriable; 

}

$one = "this is my class"; 
$two = "I$one = "this is my class"; 
$mym
$myclass->one($one); 
$myclass->display();

$myclass->one($one, $two); 
$myclass->display();

//本例的做法,在PHP 中是不正確的! 
?>


使用過 C++、Java、C# 重載的人,很習慣就會寫出以上的重載實作的 PHP 程式碼。但這在 PHP5 中是不正確的。 PHP5 並不是對前述幾種語言的模仿,而是有自己的一套實作方法重載的方法(是好是壞,這裡不討論)。 雖然 PHP5 的類別較 PHP4 強大了許多,但在「重載」這個問題上並沒有像我們預期的那樣「改善」。在“強”類型的語言中可以透過不同的參數類型來實現“重載”,例如C++、Java、C# 等。在「固定參數」傳遞的語言中,也可以透過參數的數量傳遞,例如 Java,但是 PHP 是弱型別語言,因此不會出現類似以上的「重載」。

PHP5 中重載可以透過 __get, __set, and __call 幾個特殊方法來進行。當 Zend 引擎試圖存取一個成員並沒有找到時,PHP將會呼叫這些方法。

在以下範例中,__get和__set取代所有對屬性變數數組的存取。如果必要,你還可以實現任何類型你想要的過濾。例如,腳本可以禁止設定屬性值, 在開始時用一定的前綴或包含一定類型的值。 __call 方法說明了你如何呼叫未經定義的方法。當你呼叫未定義方法時,方法名稱和方法接收的參數將會傳給__call方法, PHP傳遞__call的值傳回給未定義的方法。


程式碼如下:

class Overloader 

private $properties = array();


function __get($property_name)y();

function __get($property_name) .

return($this->properties[$property_name]); 

else 

return(NULL); 

}
}
> properties[$property_name] = $value; 
}

public function __call($method, $p) 

print("Invoking $method()
n"); 
//print("Arguments: "); 
//print_r($args); if($method == 'display') 

if(is_object($p[0])) 
$this->displayObject($p[0]); 
else 
if(is_array($p[0] )) 
$this->displayArray($p[0]); 
else 
$this->displayScalar($p[0]); 

}
public function display($p) "你傳入的是個對象,內容如下:
"); 

print_r($p); 

echo "


"; 
}

public function displayArray($p) 

e ( 傳入的是個數組,內容如下:
"); 

print_r($p); 
echo "


"; 
}

public function displayScalar($p) 
{ public function displayScalar($p) 


e (的是單獨變量,內容如下:
" . $p); 
echo "


"; 

}
$o = new Overloader();

//調用__set() 給一個不存在的屬性變數賦值 

$o->dynaProp = "Dynamic Content";

//呼叫__get() 

print($o->dynaProp . "
n");

//呼叫_ _call() 

//$o->dynaMethod("Leon", "Zeev");

$o->display(array(1,2,3)); 

$o->display('Cat') ; 
?>

以上程式碼中,呼叫了display() 方法,可以根據參數的類型和個數呼叫類別中的對應的程式碼段,從而實現了物件方法的重載。

感謝您的閱讀,想要更多的相關內容請關注PHP中文網(www.php.cn)!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門推薦
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板