1. php面向對象有哪些魔術方法
__construct(), __destruct(), __call(), __callStatic(), __get(), __set(), __isset(), __unset(), __sleep(), __wakeup(), __toString(),__invoke(), __set_state(), __clone() 和 __debugInfo() 等方法在 PHP 中被稱為"魔術方法"(Magic methods)。
2. php魔術方法。。
在 PHP 里,將所有以 __(兩個下劃線)開頭的類方法保留為魔術方法,所以在定義類方法時,除了上述魔術方法,建議不要以 __ 為前綴。
魔術方法的引入是對面向對象編程思想的進一步實現,重載就是通過魔術方法來實現的。
PHP 魔術方法主要有:
__construct(), __destruct(), __call(), __callStatic(), __get(), __set(), __isset(), __unset(),__sleep(), __wakeup(), __toString(), __invoke(), __set_state(), __clone() 和 __debugInfo() 等。
最常見的是__construct(), __destruct(),__get(), __set()等:
__construct和__destruct是類的構造函數和析構函數。
3. php5中魔術方法函數有哪幾個,請舉例說明各自的用法
__construct() :實例化對象時被調用;
__destuct():當刪除一個對象或者對象操作終止是被執行;
__call():調用對象不存在方法時被調用;
__get():調用對象不存在的屬性時被調用;
__set():設置對象不存在的屬性時被調用;_
_toString():列印一個對象時被調用,比如echo $obj,print($obj);
__clone():克隆對象時被調用,比如$t = new Test();$tt = clone $t;
__sleep():serialize之前被調用,若對象比較大,想做一些刪除在序列化,可以考慮使用該方法;
__wakeup():unserialize之前被調用,做些對象的初始化;
__isset():檢測對象是否存在屬性的時候被調用,如 isset($c->name);
__unset():unset一個對象屬性時被調用,如:unset($c->name);
__set_state():調用var_export時被調用,用__set_state的返回值作為 var_export的返回值;,
__autoload():實例化一個對象時,如果對應的類不存在,在該方法被調用。
希望你能採納,謝謝。
4. php魔術方法怎麼用
在 PHP 里,將所有以 __(兩個下劃線)開頭的類方法保留為魔術方法。魔術方法的引入是對面向對象編程思想的進一步實現,重載就是通過魔術方法來實現的。主要有:
__construct(), __destruct(), __call(), __callStatic(), __get(), __set(), __isset(), __unset(),__sleep(), __wakeup(), __toString(), __invoke(), __set_state(), __clone() 和 __debugInfo() 等函數。
5. php中常用的魔術方法有哪些
php規定以兩個下劃線__開頭的方法都保留為魔術方法,建議自定義函數的函數名最好避開。
__construct() 實例化類時自動調用。
__destruct() 類對象使用結束時自動調用。
__set() 在給未定義的屬性賦值的時候調用。
__get() 調用未定義的屬性時候調用。
__isset() 使用isset()或empty()函數時候會調用。
__unset() 使用unset()時候會調用。
__sleep() 使用serialize序列化時候調用。
__wakeup() 使用unserialize反序列化的時候調用。
__call() 調用一個不存在的方法的時候調用。
__callStatic()調用一個不存在的靜態方法是調用。
__toString() 把對象轉換成字元串的時候會調用。比如 echo。
__invoke() 當嘗試把對象當方法調用時調用。
__set_state() 當使用var_export()函數時候調用。接受一個數組參數。
__clone() 當使用clone復制一個對象時候調用。
6. php5 中魔術方法函數有哪幾個
魔術函數:
9.3 構造函數:__construct()
9.3.1 實例化對象時被調用。
9.3.2 在類中,構造函數是用來初始化對象的,利用構造函數,可以操作對象,並改變它的值。
9.3.3 當__construct和以類名為函數名的函數同時存在時,__construct將被調用,另一個不被調用。
9.3.4 當子類重寫了構造函數,子類被實例化時,只調用子類的構造函數,而父類的構造函數不被調用。
9.4 析構函數:__destruct()
9.4.1 當刪除一個對象或對象操作終止時被調用。
9.4.2 當該對象的所有引用都被刪除,或者對象被顯式銷毀時執行。
9.5 克隆函數:__clone()
9.5.1 當對象被拷貝(克隆)時直接調用。
9.5.2 如$a = new Action(); $a = $object;
9.6 __set($name, $value)
9.6.1 用$object->a = 17的方式給屬性賦值時,如果屬性a存在且是public型,那麼直接給屬性a賦值皆可;
9.6.2 如果屬性a不存在或者是protected/private型,就會調用__set($name, $value)方法。
9.6.3 二個參數:屬性、屬性值。
9.7 __get($name)
9.7.1 用$object->a的方式讀取對象的屬性時,如果屬性a存在且是public型,那麼直接返回該屬性的值;
9.7.2 如果屬性a不存在或者是protected/private修飾的不可直接訪問的類型,就會調該方法並以返回值為准。
9.7.3 一般可以使用該方法使外部可限制性地訪問內部屬性,或者完成類似java中的反射操作。
9.8 __isset($name)
9.8.1 檢測一個對象的屬性是否存在時被調用。
9.8.2 如:isset($c->name),如果name不存在,則觸發該函數。
9.8.3 對不存在或者不可訪問的屬性使用isset()或者empty()時,__isset()會被調用。
9.9 __unset($name)
9.9.1 銷毀一個對象的屬性時被調用。
9.9.2 如:unset($c->name),如果name不存在,則觸發該函數。
9.9.3 當unset一個不存在或者不可訪問的屬性時,__unset()會被調用,否則直接unset該屬性皆可。
9.10 __call($name, $arguments)
9.10.1 當調用不存在或者不可訪問的方法時,會調用__call($name, $arguments)方法。
9.11 __callStatic($name, $arguments)
9.11.1 當在靜態方法中調用不存在或者不可訪問的方法時,會調用__callStatic($name, $arguments)方法。
9.11.2 這個方法 是PHP5.3里才添加的,比較新。
9.12 __toString()
9.12.1 當列印對象時會被直接調用。如 echo $object; 或 print $obj;
9.12.2 注意:這時候php會拋出一個Catchable fatal error錯誤;用print_r列印對象不會觸發此函數。
9.13 __set_state()
9.13.1 用var_export()輸出一個對象時,__set_state()會被調用,輸出內容以該魔術方法的返回值為准。
9.13.2 註:var_export()和var_mp()類似,只是var_export()輸出的內容符合php語法。
9.14 __autoload($name)
9.14.1 實例化一個對象時,如果對應的類不存在,則該方法被調用。
9.14.2 這個函數比較特殊,這個函數並不是作為類的成員方法使用的。
9.14.3 注意:該方法是全局函數,參數是類的名稱。
9.14.4 可以用spl_autoload_register函數來定義其他的函數來代替__autoload
9.15 __sleep()
9.15.1 serialize之前被調用。若對象比較大,想刪減一點東東再序列化,可考慮一下此函數。
9.16 __wakeup()
9.16.1 unserialize時被調用,做些對象的初始化工作。
7. php什麼是魔術方法
__construct(),
__destruct(),
__call(),
__callStatic(),
__get(),
__set(),
__isset(),
__unset(),
__sleep(),
__wakeup(),
__toString(),
__invoke(),
__set_state(),
__clone()
和
__debugInfo()
等方法在
PHP
中被稱為"魔術方法"(Magic
methods)。在命名自己的類方法時不能使用這些方法名,除非是想使用其魔術功能。
8. PHP魔術方法__GET、__SET使用實例
__get()-
讀取不可訪問屬性的值時,__get()
會被調用。
__set()-
在給不可訪問屬性賦值時,__set()
會被調用。
復制代碼
代碼如下:
<?php
/**
*
清晰的認識__get()
__set()
*/
class
Example
{
//公有的屬性
public
$public
=
'pub'
;
//受保護的
-
子類中該屬性可用
protected
$protected
=
'pro';
//私有的
-
只能此類使用此屬性
private
$private
=
'pri';
//當訪問對象中的屬性不存在或者非公有屬性的時候自動載入__get()方法
public
function
__get($name){
return
'調用__get()方法:'.$name;
}
//當給對象的一個屬性賦值的時候如果該屬性不存在或者是非公有屬性則自動載入__set()方法
public
function
__set($name,$value){
echo
"\nname:".$name.',value:'.$value."\n";
}
}
$example
=
new
Example;
echo
'<pre>';
echo
$example->public."\n";
echo
$example->protected."\n";
echo
$example->private."\n";
echo
$example->other."\n";
echo
'<hr>';
$example->public
=
'lic';
//這個賦值成功所有沒有顯示
$example->protected
=
'tec';
$example->private
=
'vat';
$example->other
=
'er';
echo
'<br/>';
echo
'列印
public
屬性:'.$example->public;
9. php魔術方法__tostring
__tostring()方法:在直接輸出對象引用的時候,就不會產生錯誤,而是自動調用了__tostring()方法,輸出__tostring()方法中返回的字元串
通俗來說就是 對象一般是使用print_r() 或 var_mp() 來列印訪問
但對於一般閑的人來說直接 使用 echo 輸出對象時,必定會報錯的,原因是對象無法使用echo的。
這個時候如果想解決這個錯誤,咱們應該怎麼操作呢?
可以很好的利用__tostring()這個魔術方法
但是切記使用__toString() 時返回值一定要使用return 來進行返回。
<?php
header("content-type:text/html;charset=utf-8");
class demo{
public $foo;
public function __construct($foo){
$this->foo=$foo;
}
//定義一個__toString()方法時,返加一個成員屬性$foo
public function __toString(){
return $this->foo;
}
}
$demo=new demo('hello PHP成員');
echo $demo;
10. PHP __get和__set魔術方法在面向對象中的使用問題
php的面向對象思想編程中聲明方法有三種不同的許可權:public protect private。
public:許可權是最大的,可以內部調用,實例調用等。
protected: 受保護類型,用於本類和繼承類調用。
private: 私有類型,只有在本類中使用。
這些許可權同樣可以應用在變數聲明中。
__set __get 都是php的魔術方法,主要是為了用來改變類的私有屬性用的。
你覺得麻煩可以將private私有的變數改為公共public變數,這個要看需求和個人對面向對象的思考。
追問 : 我想知道的是(用private封裝然後用__set或者__get )和(public設置類的屬性)有什麼不同.都可以取值賦值.
追答 : 沒什麼不同的,實現的效果都一樣,只是private是為了限制訪問入口少一些,或者之前用private時沒有考慮到有如今的調用情況,所以在加了set或get。 比較public是所有人都可以訪問,private是內部人可以訪問,從許可權來看,private會安全一些。