首頁  >  文章  >  後端開發  >  php魔術方法

php魔術方法

伊谢尔伦
伊谢尔伦原創
2016-11-23 13:58:211482瀏覽

 __construct(),__destruct(),__call(),__callStatic(),__get(),__set(),__isset(),__unset(),__sleep(),__wakeup(),__toString(),__invoke(),__set_state ()和 __clone() 等方法在 PHP 中稱為"魔術方法"(Magic methods)。在命名自己的類別方法時不能使用這些方法名,除非是想使用其魔術功能。

PHP 將所有以 __(兩個底線)開頭的類別方法保留為魔術方法。所以在定義類別方法時,除了上述魔術方法,建議不要以 __ 為前綴。

__sleep() 和 __wakeup()

publicarray__sleep ( void )

void__wakeup ( void )

serialize( )如果存在,該方法會先被調用,然後再執行序列化操作。此功能可用於清理對象,並傳回一個包含對像中所有應被序列化的變數名稱的陣列。如果方法未回傳任何內容,則 NULL 被序列化,並產生一個 E_NOTICE 等級的錯誤。

注意:

__sleep() 不能回傳父類的私有成員的名字。這樣做會產生一個 E_NOTICE 等級的錯誤。可以用 Serializable 介面來替代。

__sleep() 方法常用於提交未提交的數據,或類似的清理操作。同時,如果有一些很大的對象,但不需要全部保存,這個功能就很好用。

與之相反, unserialize() 會檢查是否有一個 __wakeup() 方法。如果存在,則會先呼叫 __wakeup 方法,並預先準備物件所需的資源。

__wakeup() 常用在反序列化操作中,例如重新建立資料庫連接,或執行其它初始化操作。

Example #1 Sleep 和 wakeup

class Connection
{
    protected $link;
    private $server,$username,$password,$db;
    public function __construct($server,$username,$password,$db)
    {
        $this->server = $server;
        $this->username = $username;
        $this->password = $password;
        $this -> db = $db;
        $this -> connect();
    }
    private function connect(){
        $this -> link = mysql_connect($this->server,$this->username,$this->password);
        mysql_select_db($this->db,$this->link);
    }
    public function __sleep(){
        return array('server','username','password','db');
    }
    public function __wakeup(){
        $this->connect();
    }
}

__toString()

public string __toString ( void )

__toString() 方法用於一個類別被當成對字串時應回應。例如 echo $obj; 應該顯示些什麼。此方法必須傳回字串,否則將發出一個 E_RECOVERABLE_ERROR 等級的致命錯誤。

不能在 __toString() 方法中拋出異常,這樣做會導致致命錯誤。

Example #2 簡單範例

class TestClass
{
    public $foo;
    public function __construct($foo)
    {
        $this->foo = $foo;
    }
    public function __toString(){
        return $this->foo;
    }
}
$class = new TestClass('Hello');
echo $class;

輸出結果:

Hello

需要指出的是在 PHP 5.2.0 之前,__toString() 方法只有在直接使用於 echo 或 print 時才能生效。 PHP 5.2.0 之後,則可以在任何字串環境生效(例如透過 printf(),使用 %s 修飾符),但不能用於非字串環境(如使用 %d 修飾符)。自 PHP 5.2.0 起,若將未定義 __toString() 方法的物件轉換為字串,則會產生 E_RECOVERABLE_ERROR 層級的錯誤。

__invoke()

mixed__invoke ([ $... ] )

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

注意:

本特性只在 PHP 5.3.0 以上版本有效。

Example #3 使用 __invoke()

class CallableClass
{
    function __invoke($x){
        var_dump($x);
    }
}
$obj = new CallableClass;
$obj(5);
var_dump(is_callable($obj));

輸出結果:

int(5)

bool(true)

__set_state()

bool(true)

__set_state()

bool(true 5.1.0 起當呼叫 var_export() 導出類別時,此靜態方法會被呼叫。

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

Example #4 使用 __set_state()>(PHP 5.1.0 起)

class A
{
    public $var1;
    public $var2;
    public static function __set_state($an_array)
    {
        $obj = new A;
        $obj -> var1 = $an_array['var1'];
        $obj -> var2 = $an_array['var2'];
        return $obj;
    }
}
$a = new A;
$a->var1 = 5;
$a->var2 = 'foo';
eval('$b='.var_export($a,true).';');
var_dump($b);

輸出結果:

object(A)#2 (2) { ["var1"]=> int(5) ["var2" ]=> string(3) "foo" }

🎜🎜
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn