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 ) 當調用一個未定義的方法是調用此訪求
這裡的未定義的方法包括沒有權限通路的方法
4、__autoload
__autoload 函數,它會在試圖使用尚未被定義的類時自動調用。通過調用此函數,腳本引擎在 PHP 出錯失敗前有了最後一個機會加載所需的類。
注意: 在 __autoload 函數中抛出的異常不能被 catch 語句塊捕獲并導緻緻命錯誤。
5、__construct、__destruct
__construct 構造方法,當一個對象建立時調用此方法,使用此方法的好處是:可以使構造方法有一個獨一無二的名稱,無論它所在的類的名稱是什麼.這樣你在改變類的名稱時,就不需要改變構造方法的名稱
__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() 魔術方法必須被定義為公共的,所有其他魔術方法都必須如此。