php如何認識魔術方法

2020-09-29 15:01:01

在php中將所有以「__」即兩個下劃線開頭的類方法保留為魔術方法,PHP中魔術方法有「__construct()」、「__destruct()」、「__call()」、「__callStatic()」等等。

魔術方法有:

1、__get、__set

這兩個方法是為在類和他們的父類別中沒有宣告的屬性而設計的

__get( $property ) 當呼叫一個未定義的屬性時,此方法會被觸發,傳遞的引數是被存取的屬性名

__set( $property, $value ) 給一個未定義的屬性賦值時,此方法會被觸發,傳遞的引數是被設定的屬性名和值

這裡的沒有宣告包括當使用物件呼叫時,存取控制為proteced,private的屬性(即沒有許可權存取的屬性)。

2、__isset、__unset

__isset( $property ) 當在一個未定義的屬性上呼叫isset()函數時呼叫此方法

__unset( $property ) 當在一個未定義的屬性上呼叫unset()函數時呼叫此方法

與__get方法和__set方法相同,這裡的沒有宣告包括當使用物件呼叫時,存取控制為proteced,private的屬性(即沒有許可權存取的屬性)

3、__call

__call( $method, $arg_array ) 當呼叫一個未定義的方法是呼叫此方法

這裡的未定義的方法包括沒有許可權存取的方法;如果方法不存在就去父類別中找這個方法,如果父類別中也不存在就去呼叫本類的__call()方法,如果本類中不存在__call()方法就去找父類別中的__call()方法

4、__autoload

__autoload 函數,它會在試圖使用尚未被定義的類時自動呼叫。通過呼叫此函數,指令碼引擎在 PHP 出錯失敗前有了最後一個機會載入所需的類。

如果要定義一個全域性的自動載入類,則必須用spl_autoload_register()方法將處理類註冊到PHP標準庫:

程式碼如下:

<?php   
class Loader   
{   
static function autoload_class($class_name)   
{   
//尋找正確的$class_name類,並引入,沒有則丟擲異常   
}   
}   
/**
*   設定物件的自動載入
*   spl_autoload_register — Register given function as __autoload() implementation
*/   
spl_autoload_register(array('Loader', 'autoload_class'));   
$a = new Test();//Test沒用require就範例化,實現自動載入,很多框架就用這種方法自動載入類   
?>

注意: 在 __autoload 函數中丟擲的異常不能被 catch 語句塊捕獲並導致致命錯誤,所以應該在函數本身做捕獲。

5、__construct、__destruct

__construct 構造方法,當一個物件建立時呼叫此方法,相對於PHP4使用此方法的好處是:可以使構造方法有一個獨一無二的名稱,無論它所在的類的名稱是什麼.這樣你在改變類的名稱時,就不需要改變構造方法的名稱

__destruct 解構方法,PHP將在物件被銷燬前(即從記憶體中清除前)呼叫這個方法。預設情況下,PHP僅僅釋放物件屬性所佔用的記憶體並銷燬物件相關的資源,解構函式允許你在使用一個物件之後執行任意程式碼來清除記憶體。當PHP決定你的指令碼不再與物件相關時,解構函式將被呼叫。

在一個函數的名稱空間內,這會發生在函數return的時候。

對於全域性變數,這發生於指令碼結束的時候。

如果你想明確地銷燬一個物件,你可以給指向該物件的變數分配任何其它值.通常將變數賦值勤為NULL或者呼叫unset.

6、__clone

PHP5中的物件賦值是使用的參照賦值,如果想複製一個物件則需要使用clone方法,在呼叫此方法是物件會自動呼叫__clone魔術方法,如果在物件複製需要執行某些初始化操作,可以在__clone方法實現。

7、__toString

__toString方法在將一個物件轉化成字串時自動呼叫,比如使用echo列印物件時。

如果類沒有實現此方法,則無法通過echo列印物件,否則會顯示:Catchable fatal error: Object of class test could not be converted to string in

此方法必須返回一個字串。

在PHP 5.2.0之前,__toString方法只有結合使用echo() 或 print()時 才能生效。PHP 5.2.0之後,則可以在任何字串環境生效(例如通過printf(),使用%s修飾符),但 不能用於非字串環境(如使用%d修飾符)。從PHP 5.2.0,如果將一個未定義__toString方法的物件 轉換為字串,會報出一個E_RECOVERABLE_ERROR錯誤。

8、__sleep、__wakeup

__sleep 序列化的時候用

__wakeup 反序列化的時候呼叫

serialize() 檢查類中是否有魔術名稱 __sleep 的函數。如果這樣,該函數將在任何序列化之前執行。它可以清除物件並應該返回一個包含有該物件中應被序列化的所有變數名的陣列。

使用 __sleep 的目的是關閉物件可能具有的任何資料庫連線,提交等待中的資料或進行類似的清除任務。此外,如果有非常大的物件而並不需要完全儲存下來時此函數也很有用。

相反地,unserialize() 檢查具有魔術名稱 __wakeup 的函數的存在。如果存在,此函數可以重建物件可能具有的任何資源。

使用 __wakeup 的目的是重建在序列化中可能丟失的任何資料庫連線以及處理其它重新初始化的任務。

9、__set_state

當呼叫var_export()時,這個靜態 方法會被呼叫(自PHP 5.1.0起有效)。

本方法的唯一引數是一個陣列,其中包含按array('property' => value, …)格式排列的類屬性。

10、__invoke

當嘗試以呼叫函數的方式呼叫一個物件時,__invoke 方法會被自動呼叫。

PHP5.3.0以上版本有效

11、__callStatic

它的工作方式類似於 __call() 魔術方法,__callStatic() 是為了處理靜態方法呼叫,

PHP5.3.0以上版本有效

PHP 確實加強了對 __callStatic() 方法的定義;它必須是公共的,並且必須被宣告為靜態的。同樣,__call() 魔術方法必須被定義為公共的,所有其他魔術方法都必須如此

想了解更多程式設計學習,敬請關注欄目!

以上就是php如何認識魔術方法的詳細內容,更多請關注TW511.COM其它相關文章!