1. 程式人生 > >PHP中的魔術方法和關鍵字

PHP中的魔術方法和關鍵字

 

PHP中的魔術方法總結 :__construct, __destruct , __call, __callStatic,__get, __set, __isset, __unset , __sleep, __wakeup, __toString, __set_state, __clone and __autoload

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() 魔術方法必須被定義為公共的,所有其他魔術方法都必須如此。

 

關鍵字:

final :

1、final不能修飾成員屬性

2、final只能修飾類和方法

 

final作用:

1、使用final修飾的類不能被子類繼續

2、使用final修飾的方法不能被子類去覆蓋

3、用來限制類不被繼承,方法不被覆蓋就使用final

 

static:

1、使用static可以修飾成員的屬性和成員的方法,不能修飾類

2、使用static修飾的成員屬性,可以被同一個類的所有物件共享

3、靜態的資料是存在記憶體中的 資料段 中(初始化靜態段)

4、靜態的資料是在類麼一次載入時,分配到記憶體中的,以後再用到類時就直接從資料段中獲取

5、什麼是類被載入?只要在程式中使用到這個類(有這個類名出現)

6、靜態方法(static修飾的方法),不能訪問非靜態的成員(在非靜態的方法中,可以訪問靜態成員),因為非靜態的成員,就必須用物件來訪問,訪問內部的成員使用的就是$this,靜態方法 不用使用物件來呼叫,也就沒有物件,$this也就不能代表什麼物件,非靜態的成員還必須使用物件,如果你確定一個方法不使用非靜態的成員,則可以將這個方法宣告為 靜態方法(不用建立物件,直接使用類名就可以訪問)

 

靜態成員:類名::成員   ,在內部訪問其它成員:self::成員

 

Ps:靜態的成員都要使用類名去訪問,不用建立物件 (類名::靜態成員),如果在類中使用靜態成員,可以使用self::靜態成員

 

const:

1、它只能修飾成員屬性

2、類名中宣告常量屬性使用const

3、類名的方式和我們以前學習的define是一樣的效果

4、訪問方式個static靜態成員屬性是一樣的(在類外部使用:類名::常量  ,在類內部使用: self::常量)

5、常量一定要在宣告時給初值

  轉載自:https://www.cnblogs.com/zuochuang/p/7306795.html  

PHP中的魔術方法總結 :__construct, __destruct , __call, __callStatic,__get, __set, __isset, __unset , __sleep, __wakeup, __toString, __set_state, __clone and __autoload

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() 魔術方法必須被定義為公共的,所有其他魔術方法都必須如此。

 

關鍵字:

final :

1、final不能修飾成員屬性

2、final只能修飾類和方法

 

final作用:

1、使用final修飾的類不能被子類繼續

2、使用final修飾的方法不能被子類去覆蓋

3、用來限制類不被繼承,方法不被覆蓋就使用final

 

static:

1、使用static可以修飾成員的屬性和成員的方法,不能修飾類

2、使用static修飾的成員屬性,可以被同一個類的所有物件共享

3、靜態的資料是存在記憶體中的 資料段 中(初始化靜態段)

4、靜態的資料是在類麼一次載入時,分配到記憶體中的,以後再用到類時就直接從資料段中獲取

5、什麼是類被載入?只要在程式中使用到這個類(有這個類名出現)

6、靜態方法(static修飾的方法),不能訪問非靜態的成員(在非靜態的方法中,可以訪問靜態成員),因為非靜態的成員,就必須用物件來訪問,訪問內部的成員使用的就是$this,靜態方法 不用使用物件來呼叫,也就沒有物件,$this也就不能代表什麼物件,非靜態的成員還必須使用物件,如果你確定一個方法不使用非靜態的成員,則可以將這個方法宣告為 靜態方法(不用建立物件,直接使用類名就可以訪問)

 

靜態成員:類名::成員   ,在內部訪問其它成員:self::成員

 

Ps:靜態的成員都要使用類名去訪問,不用建立物件 (類名::靜態成員),如果在類中使用靜態成員,可以使用self::靜態成員

 

const:

1、它只能修飾成員屬性

2、類名中宣告常量屬性使用const

3、類名的方式和我們以前學習的define是一樣的效果

4、訪問方式個static靜態成員屬性是一樣的(在類外部使用:類名::常量  ,在類內部使用: self::常量)

5、常量一定要在宣告時給初值