您好,登錄后才能下訂單哦!
PHP5中魔術方法的作用有哪些?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
從PHP 5以后的版本,PHP中的類就可以使用魔術方法了。其規定以兩個下劃線(__)開頭的方法都保留為魔術方法,所以建議大家函數名最好不用__開頭,除非是為了重載已有的魔術方法。
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
PHP 5中的對象賦值是使用的引用賦值,如果想復制一個對象則需要使用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(PHP 5.3.0以上版本有效)
當嘗試以調用函數的方式調用一個對象時,__invoke 方法會被自動調用。
11、__callStatic(PHP 5.3.0以上版本有效)
它的工作方式類似于__call() 魔術方法,__callStatic() 是為了處理靜態方法調用。
關于PHP5中魔術方法的作用有哪些問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。