這篇文章主要簡單介紹了PHP 魔術變量和魔術函數,以及使用示例,方便我們學習理解php魔術變量和魔術函數,有需要的小伙伴參考下吧。
魔術變量
PHP 向它運行的任何腳本提供了大量的預定義常量。
不過很多常量都是由不同的擴展庫定義的,只有在加載了這些擴展庫時才會出現,或者動態加載後,或者在編譯時已經包括進去了。
有八個魔術常量它們的值隨著它們在代碼中的位置改變而改變。
例如 __LINE__ 的值就依賴於它在腳本中所處的行來決定。這些特殊的常量不區分大小寫,如下:
__LINE__
文件中的當前行號。
實例:
代碼如下:
以上實例輸出結果為:
代碼如下:
__FILE__
文件的完整路徑和文件名。如果用在被包含文件中,則返回被包含的文件名。
自 PHP 4.0.2 起,__FILE__ 總是包含一個絕對路徑(如果是符號連接,則是解析後的絕對路徑),而在此之前的版本有時會包含一個相對路徑。
實例:
代碼如下:
以上實例輸出結果為:
代碼如下:
__DIR__
文件所在的目錄。如果用在被包括文件中,則返回被包括的文件所在的目錄。
它等價於 dirname(__FILE__)。除非是根目錄,否則目錄中名不包括末尾的斜槓。(PHP 5.3.0中新增)
實例:
代碼如下:
以上實例輸出結果為:
代碼如下:
__FUNCTION__
函數名稱(PHP 4.3.0 新加)。自 PHP 5 起本常量返回該函數被定義時的名字(區分大小寫)。在 PHP 4 中該值總是小寫字母的。
實例:
代碼如下:
以上實例輸出結果為:
代碼如下:
__CLASS__
類的名稱(PHP 4.3.0 新加)。自 PHP 5 起本常量返回該類被定義時的名字(區分大小寫)。
在 PHP 4 中該值總是小寫字母的。類名包括其被聲明的作用區域(例如 FooBar)。注意自 PHP 5.4 起 __CLASS__ 對 trait 也起作用。當用在 trait 方法中時,__CLASS__ 是調用 trait 方法的類的名字。
實例:
代碼如下:
以上實例輸出結果為:
類名為:test
函數名為:_print
__TRAIT__
Trait 的名字(PHP 5.4.0 新加)。自 PHP 5.4.0 起,PHP 實現了代碼復用的一個方法,稱為 traits。
Trait 名包括其被聲明的作用區域(例如 FooBar)。
從基類繼承的成員被插入的 SayWorld Trait 中的 MyHelloWorld 方法所覆蓋。其行為 MyHelloWorld 類中定義的方法一致。優先順序是當前類中的方法會覆蓋 trait 方法,而 trait 方法又覆蓋了基類中的方法。
代碼如下:
以上例程會輸出:
代碼如下:
__METHOD__
類的方法名(PHP 5.0.0 新加)。返回該方法被定義時的名字(區分大小寫)。
實例:
復制代碼 代碼如下:
以上實例輸出結果為:
代碼如下:
__NAMESPACE__
當前命名空間的名稱(區分大小寫)。此常量是在編譯時定義的(PHP 5.3.0 新增)。
實例:
代碼如下:
以上實例輸出結果為:
代碼如下:
魔術函數
__construct()
實例化對象時被調用,
當__construct和以類名為函數名的函數同時存在時,__construct將被調用,另一個不被調用。
__destruct()
當刪除一個對象或對象操作終止時被調用。
__call()
對象調用某個方法,
若方法存在,則直接調用;
若不存在,則會去調用__call函數。
__get()
讀取一個對象的屬性時,
若屬性存在,則直接返回屬性值;
若不存在,則會調用__get函數。
__set()
設置一個對象的屬性時,
若屬性存在,則直接賦值;
若不存在,則會調用__set函數。
__toString()
打印一個對象的時被調用。如echo $obj;或print $obj;
__clone()
克隆對象時被調用。如:$t=new Test();$t1=clone $t;
__sleep()
serialize之前被調用。若對象比較大,想刪減一點東東再序列化,可考慮一下此函數。
__wakeup()
unserialize時被調用,做些對象的初始化工作。
__isset()
檢測一個對象的屬性是否存在時被調用。如:isset($c->name)。
__unset()
unset一個對象的屬性時被調用。如:unset($c->name)。
__set_state()
調用var_export時,被調用。用__set_state的返回值做為var_export的返回值。
__autoload()
實例化一個對象時,如果對應的類不存在,則該方法被調用。
以上就是本文的全部內容了,小伙伴們是否對魔術變量和魔術函數有了新的認識了呢,希望大家喜歡本文內容。