常用的魔術方法有:__Tostring () __Call() __autoLoad() __ clone() __GET() __SET() __isset() __unset()
1.__Tostring() 用於定義輸出對象引用時調用 常用於打印一些對象的信息 必須有返回值
eg:有一個persion類
Persion per =new persion()
Echo per; //直接調用會出錯
我們可以在類的定義中添加__tostring()方法
復制代碼 代碼如下:
Function __Tostring()
{
$str=this->$name.this->age;
Return $str;
}
2.__clone()對象的復制
引用賦值
$per1=$per2; 而這在內存中只有一塊地址
而$per1=clone $per2 這時有兩塊內存地址
3.__call()方法 當調用類實例中不存在的函數時自動執行
如果試圖調用類中不存在的函數,會出現語法錯誤,為了能夠友好的提示
我們可以在類中聲明Call()方法;
復制代碼 代碼如下:
Function __call($funName,$argu)
{
Echo "名為".$funName."參數為".printf($argh)."的函數不存在",
}
4.__autoLoad 自動加載使用的類文件 該函數是在引用的頁面添加
我們都使用過這樣情況,在頁面中需要調用其他php文件,我們需要使用include方法
但是如果有幾十個頁面需要引用,未免太過繁瑣,我們可以在該頁面中使用autoload方法
復制代碼 代碼如下:
Function __autoload($className)
{
Include $className.".php";
}
這樣凡是引用到其他類的地方,都會自動引用該類文件 前提類文件的名稱必須是 類名.php
5.__GET() 訪問類中私有屬性
如果類中的屬性設置為私有屬性,在類的實例中是無法訪問的,但怎樣才能訪問呢?
我們就可以使用__GET()
Eg :
類中有
復制代碼 代碼如下:
Class person
{
Private $name;
Private $age;
}
實例化 person per=new person()
Per->$name; //這樣是取不到值的
但是如果我們在類中增加__GET方法
復制代碼 代碼如下:
Function __GET($proName)
{
Return this->$proName;
}
我們再次調用Per->$name 就可以訪問了
這樣做有人會提出疑問了,這樣可以直接訪問私有變量,和聲明成公有的有什麼區別呢?
如果聲明成公有的,我們可以任意讀取,如果是私有,如果我們增加了get方法,那麼每次調用私有屬性都會調用GET方法的內容,這樣我們就可以在get方法中增加一些邏輯處理。
6.__SET()設置類中的私有屬性
原理同上,我們可以再類中添加__SET()函數,每當通過調用類實例給私有屬性賦值,都會執行__SET函數 ,函數原型:
復制代碼 代碼如下:
Function __SET($proName,$value)
{
This->$proName=$value;
}
既然是方法賦值,我們就可以做一些邏輯處理
7.__isset() 判斷類中私有屬性或方法是否存在時自動調用
首先我們先介紹一下isset 方法,該方法用於判定屬性和方法是否存在,但是我們無法通過類類實例判斷類中的某個私有屬性是否存在
如果我們使用isset(per->$name);//返回值是false,但是$name屬性的確存在,怎麼解決呢?
解決方法:
1.將$name定義為私有屬性
2.在類定義中添加
復制代碼 代碼如下:
Function __isset($proName)
{
Return isset(this->$proName);//再類內部是可以訪問私有屬性的
}
這樣的話我們再次調用isset($name);返回值就為true了;
8.__unset()清除類中私有變量時自動調用
與之結合的是unset() unset方法可以刪除屬性,當我們需要刪除類中屬性的時候,如果是公有屬性我們可以直接
刪除,但是如果是私有我們只通過該方法就無法實現了
怎樣實現呢我們可以使用__unset()方法實現該功能我們需要在類中添加
復制代碼 代碼如下:
Function __unset($proName)
{
Unset(this->$proName);
}
現在我們再調用unset($name);就可以刪除person類中的私有屬性$name了