PHP魔術常數
PHP 向它運行的任何腳本提供了大量的預定義常數。
不過很多常數都是由不同的擴充函式庫定義的,只有在載入了這些擴充函式庫時才會出現,或是動態載入後,或是在編譯時已經包含進去了。
PHP魔術常數有哪些?
有八個魔術常數它們的值隨著它們在程式碼中的位置改變而改變。
例如 __LINE__ 的值就依賴它在腳本中所處的行來決定。這些特殊的常數不會區分大小寫,如下:
__LINE__
檔案中的目前行號。
實例:
<?php echo '这是第 “ ' . __LINE__ . ' ” 行'; ?>以上實例輸出結果為:
这是第 “ 2 ” 行
__FILE__
檔案的完整路徑和檔案名稱。如果用在被包含檔案中,則傳回被包含的檔案名稱。
自 PHP 4.0.2 起,__FILE__ 總是包含一個絕對路徑(如果是符號連接,則是解析後的絕對路徑),而在此之前的版本有時會包含一個相對路徑。
實例:
<?php echo '该文件位于 “ ' . __FILE__ . ' ” '; ?>以上實例輸出結果為:
该文件位于 " E:\wamp\www\test\index.php "
__DIR__
檔案所在的目錄。如果用在被包含檔案中,則傳回被包含的檔案所在的目錄。
它等價於 dirname(__FILE__)。除非是根目錄,否則目錄中名不包括末尾的斜杠。 (PHP 5.3.0新增)
實例:
<?php echo '该文件位于 “ ' . __DIR__ . ' ” '; ?>以上實例輸出結果為:
该文件位于 “ E:\wamp\www\test ”
#__FUNCTION__
函數名稱(PHP 4.3.0 新加)。自 PHP 5 起本常數傳回該函數被定義時的名字(區分大小寫)。在 PHP 4 中該值總是小寫字母的。
實例:
<?php function test() { echo '函数名为:' . __FUNCTION__ ; } test(); ?>以上實例輸出結果為:
函数名为:test
__CLASS__
類別的名稱(PHP 4.3.0 新加)。自 PHP 5 起本常數傳回該類別被定義時的名字(區分大小寫)。
在 PHP 4 中該值總是小寫字母的。類別名稱包括其被宣告的作用區域(例如 Foo\Bar)。注意自 PHP 5.4 起 __CLASS__ 對 trait 也起作用。當用在 trait 方法時,__CLASS__ 是呼叫 trait 方法的類別的名字。
實例:
<?php class test { function _print() { echo '类名为:' . __CLASS__ . "<br>"; echo '函数名为:' . __FUNCTION__ ; } } $t = new test(); $t->_print(); ?>以上實例輸出結果為:
类名为:test 函数名为:_print
__TRAIT__
Trait 的名字(PHP 5.4.0 新增)。自 PHP 5.4.0 起,PHP 實作了程式碼重複使用的一個方法,稱為 traits。
Trait 名包含其被宣告的作用區域(例如 Foo\Bar)。
從基底類別繼承的成員會被插入的 SayWorld Trait 中的 MyHelloWorld 方法所覆寫。其行為 MyHelloWorld 類別中定義的方法一致。優先順序是目前類別中的方法會覆寫 trait 方法,而 trait 方法又覆寫了基底類別中的方法。
<?php class Base { public function sayHello() { echo 'Hello '; } } trait SayWorld { public function sayHello() { parent::sayHello(); echo 'World!'; } } class MyHelloWorld extends Base { use SayWorld; } $o = new MyHelloWorld(); $o->sayHello(); ?>以上例程會輸出:
Hello World!
__METHOD__
類別的方法名(PHP 5.0.0 新加)。傳回該方法被定義時的名字(區分大小寫)。
實例:
<?php function test() { echo '函数名为:' . __METHOD__ ; } test(); ?>以上實例輸出結果為:
函数名为:test
__NAMESPACE__
目前命名空間的名稱(區分大小寫)。此常數是在編譯時定義的(PHP 5.3.0 新增)。
實例:
<?php namespace MyProject; echo '命名空间为:"', __NAMESPACE__, '"'; // 输出 "MyProject" ?>以上實例輸出結果為:
命名空间为:"MyProject"