PHP4 中僅僅實現了面向對象的部分的、簡單的功能,而 PHP5 以后對對象的支持就強 " /> 久久综合久久久,六月综合网,xxxx性日本

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

php面向對象的方法重載兩種版本比較

多個函數用同一個名字,但參數表,即參數的個數或(和)數據類型可以不同,調用的時候,雖然方法名字相同,但根據參數表可以自動調用對應的函數。

php4 中僅僅實現了面向對象的部分的、簡單的功能,而 php5 以后對對象的支持就強大的多了。

對于多態的實現,php4 只支持覆蓋(override),而不支持重載(overload)。但我們可以通過一些技巧來“模擬”重載的實現。

php5 雖然可以支持覆蓋和重載,但重載在具體實現上,和其他語言還有較大的差別。

1,在 php4 中“模擬”重載

試看以下代碼:

<?php
//根據參數個數選擇執行不同的方法(在 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 方法。我們可以結合函數 func_get_arg(i) 和 func_get_args() 對以上示例進行改進。

2,在 php5 中使用重載

先看以下示例:

復制代碼 代碼如下:
<?php
class Myclass
{
public $attriable;
public $one = "this is one";
public $two = "this is two";

function __construct()
{
}

function one($one)
{
$this->one=$one;
$this->attriable = $this->one;
}

function one($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 = "Im the best";
$myclass = new myclass();
$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的值返回給未定義的方法。

復制代碼 代碼如下:
<?php
class Overloader
{
private $properties = array();

function __get($property_name)
{
if(isset($this->properties[$property_name]))
{
return($this->properties[$property_name]);
}
else
{
return(NULL);
}
}

function __set($property_name, $value)
{
$this->properties[$property_name] = $value;
}

public function __call($method, $p)
{
print("Invoking $method()<br>/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 displayObject($p)
{
echo ("你傳入的是個對象,內容如下:<br>");
print_r($p);
echo "<hr>";
}

public function displayArray($p)
{
echo ("你傳入的是個數組,內容如下:<br>");
print_r($p);
echo "<hr>";
}

public function displayScalar($p)
{
echo ("你傳入的是個單獨變量,內容如下:<br>" . $p);
echo "<hr>";
}
}

$o = new Overloader();

//調用 __set() 給一個不存在的屬性變量賦值
$o->dynaProp = "Dynamic Content";

//調用 __get()
print($o->dynaProp . "<br>/n");

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

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


以上代碼中,調用了 display() 方法,可以根據參數的類型和個數調用類中的對應的代碼段,從而實現了對象方法的重載。

php技術php面向對象的方法重載兩種版本比較,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美激情a∨在线视频播放 欧美激情不卡 | 久久综合狠狠色综合伊人 | 91九色视频| 在线观看99| 日本一区免费在线 | 国产亚洲精品97在线观看 | 成人综合婷婷国产精品久久免费 | 婷婷六月天激情 | 日韩亚洲欧美日本精品va | 日韩中文字幕在线亚洲一区 | 亚洲玖玖| 久久国产精品一区二区三区 | 天天天操天天天干 | 真正国产乱子伦高清对白 | 色婷婷av777| 黄网站视频观看免费 | 免费国产高清视频 | 人人揉揉香蕉大青草 | 激情综合色 | 丁香五月情 | 日本韩国理论片大全在线 | 久久午夜夜伦伦鲁鲁片 | 国内外成人在线视频 | 免费播放欧美一级特黄 | 一本大道香蕉久97在线视频 | 91大神麻豆 | 亚洲精品欧美综合四区 | 黄色在线视频在线观看 | 亚洲国产精品婷婷久久 | 日本网络视频www色高清免费 | 69热精品视频在线看影院 | 521香蕉永久播放地址 | 四虎新地址4hu 你懂的 | 欧美成人精品第一区二区三区 | 一二三四在线播放免费视频中国 | 91免费国产视频 | 色老板在线视频一区二区 | 九九全国免费视频 | 91久久精品日日躁夜夜躁欧美 | 婷婷狠狠干 | 欧美成人午夜视频 |