php5魔幻變量和魔幻方法

魔術常量
  1。__LINE__
  返回文件中的當前行號。
  2。__FILE__
  返回文件的完整路徑和文件名。如果用在包含文件中,則返回包含文件名。自 PHP 4.0.2 起,__FILE__ 總是包含一個絕對路徑,而在此之前的版本有時會包含一個相對路徑。
  3。__FUNCTION__
  返回函數名稱(PHP 4.3.0 新加)。自 PHP 5 起本常量返回該函數被定義時的名字(區分大小寫)。在 PHP 4 中該值總是小寫字母的。
  4。__CLASS__
  返回類的名稱(PHP 4.3.0 新加)。自 PHP 5 起本常量返回該類被定義時的名字(區分大小寫)。在 PHP 4 中該值總是小寫字母的。
  5。__METHOD__
  返回類的方法名(PHP 5.0.0 新加)。返回該方法被定義時的名字(區分大小寫)。

魔術函數:  
1。__construct()
  構造函數 : 實例化對象時被調用,
  當__construct和以類名爲函數名的構造函數同時存在時,__construct將被調用,另一個不被調用。
2。__destruct()
析構函數 : 當刪除一個對象或對象操作終止時被調用(程序結束後對象就摧毀)。
永遠都是最後執行的。
3。__call()
  對象調用某個方法,
  若方法存在,則直接調用;
若不存在,則會去調用__call函數。
4。__get()

  讀取一個對象的屬性時,若屬性存在,則直接返回屬性值;若不存在,則會調用__get函數。

5。__set()
  設置一個對象的屬性時,
  若屬性存在,則直接賦值;
  若不存在,則會調用__set函數。
6。__toString()
  打印一個對象的時被調用。如echo $obj;或print $obj;
7。__clone()
  克隆對象時被調用。如:$t=new Test();$t1=clone $t;
8。__sleep()
  serialize之前被調用。若對象比較大,想刪減一點東東再序列化,可考慮一下此函數。
9。__wakeup()
  unserialize時被調用,做些對象的初始化工作。
10。__isset()
  檢測一個對象的屬性是否存在時被調用。如:isset($c->name)。
11。__unset()
  unset一個對象的屬性時被調用。如:unset($c->name)。
12。__set_state()
  調用var_export時,被調用。用__set_state的返回值做爲var_export的返回值。
13。__autoload()

  實例化一個對象時,如果對應的類不存在,則該方法被調用。


魔術方法介紹
(1)初識魔術方法
  Php5.0發佈以來爲我們提供了很多面向對象的特性,尤其是爲我們提供了好多易用的魔術方法,這些魔術方法可以讓我們簡化我們的編碼,更好的設計我們的系統。今天我們就來認識下php5.0給我們提供的魔術方法。
PHP | 魔術方法 | __toString(),__clone(),__call(),__autoload() 詳解
__toString()
如果我有一個類:
class Person
{
private $name = “”;
private $age = 0;
function __construct($name = “”, $age = “”)
{
$this->name = $name;
$this->age = $age;
}
function say()
{
echo “name:”.$this->name.”<br/>”.”age:”.$this->age.”<br/>”;
}
}
現在我去實例化這個類,然後去打印這個實例:
$p1 = new person(“liuzy”,20);
echo $p1; //直接打印會出錯
顯然這樣直接打印對象是會出現錯誤的,因爲對象是引用句柄,不能直接打印。這時,我們可以用到__toString()方法。我們在Person類里加一個__toString()方法:
function __toString()
{
return “I am Person,my name is “.$this->name.”<br/>”;
}
然後再刷新頁面,發現什麼了?
現在我們明白,__toString()是在直接打印對象時執行的方法,我們可以用該方法打印類的一些相關信息。注意:是兩個下劃線,方法必須有返回值。
__clone()
我們知道對象是可以直接賦值的,比如
$p2 = $p1; //這裏是一個對象有兩個引用
那麼我執行:
$p1->say();
$p2->say();
是都可以執行的,而且效果一樣。
我們還有一種方法:
$p3 = clone $p1; //注意clone是克隆關鍵字,這裏與上面的不同是$p3是一個新的對象。
同時我們在類里加入一個方法:
function __clone()
{
$this->name = “我是副本”; //注意:這裏的$this是克隆產生的對象本身,不是當前類
}
然後我們執行:
$p3->say();
打印出:
name:我是副本
age:20
到這裏我們明白,__clone()方法是在克隆對象的時候執行的方法,它的作用是對新克隆出來的副本
進行屬性初始化等操作。
__call()
這個方法的主要功能是:在該類的實例調用一個不存在的方法時,執行該__call()方法。注意需要提前在類裏
聲明:
function __call($fname,$argus)
{
echo “你調用的方法:”.$fname.”不存在<br/>”;
echo “參數是”.print_r($argus);
}
聲明時包含兩個參數,第一個參數是string型,是調用的不存在的方法的方法名($fname),第二個參數是
array型,是調用的不存在的方法的參數($argus)。
__autoload()
我們在平時調用一個類的時候,必須要先將該類所在的文件引入(include “xxx.php”),如果我們在一個頁裏調用的類很多,那麼我們不得不使用許多的include “xxx.php”。顯然這樣很麻煩。
__autoload()方法可以幫我們解決這個問題。
比如我們將上面的那個Person類所在的文件定義爲 Person_class.php ,
再新建一個php文件 test.php,編輯內容:
function __autoload($calssName)
{
include $className.”_class.php”; //看到這也許你就明白了吧?哈哈
}
$p = new Person(“mifan”, 22);
$p->say();
這樣執行該test.php頁面就不會出現錯誤了。
__autoload()方法是在生命不存在的類時調用的方法,它有一個string類型的參數是聲明該不存在類的類名。

當然,類文件的命名也是很有講究的。最好是和類有關係,比如Person_class.php

__get和__set使用例子

class Tab{
protected $arr_data = array();
function __get($key){
echo "__get is called,key=$key\n";
if(isset($this->arr_data[$key])){
return $this->arr_data[$key];
}
else{
return null;
}
}
function __set($key,$val){
echo "__set is called,key=$key,val=$val\n";
$this->arr_data[$key]=$val;
}
}

$t = new Tab();

//設置Tab對象me成員的值爲"joke",由於Tab對象不含me成員,所以會調用__set($key,$val)方法
$t->me = "joke";

//獲取Tab對象me成員的值,由於Tab對象不含me成員,所以會調用__get($key)方法
$e = $t->me;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章