一:魔術函數
1。__construct()
執行個體化對象時被調用,
當__construct和以類名為函數名的函數同時存在時,__construct將被調用,另一個不被調用。
2。__destruct()
當刪除一個對象或對象操作終止時被調用。
3。__call()
對象調用某個方法,
若方法存在,則直接調用;
若不存在,則會去調用__call函數。
4。__get()
讀取一個對象的屬性時,
若屬性存在,則直接返回屬性值;
若不存在,則會調用__get函數。
5。__set()
設定一個對象的屬性時,
若屬性存在,則直接賦值;
若不存在,則會調用__set函數。
6。__toString()
列印或者輸出一個對象的時被調用。如echo $obj;或print $obj;
7。__clone()
複製對象時被調用。如:$t=new Test();$t1=clone $t; 8。__sleep()
serialize之前被調用。若對象比較大,想刪減一點東東再序列化,可考慮一下此函數。
9。__wakeup()
unserialize時被調用,做些對象的初始化工作。
10。__isset()
檢測一個對象的屬性是否存在時被調用。如:isset($c->name)。
11。__unset()
unset一個對象的屬性時被調用。如:unset($c->name)。
12。__set_state()
調用var_export時,被調用。用__set_state的傳回值做為var_export的傳回值。
13。__autoload()
執行個體化一個對象時,如果對應的類不存在,則該方法被調用。
二:魔術常量
1。__LINE__
返迴文件中的當前行號。
2。__FILE__
返迴文件的完整路徑和檔案名稱。如果用在包含檔案中,則返回包含檔案名稱。自 PHP 4.0.2 起,__FILE__ 總是包含一個絕對路徑,而在此之前的版本有時會包含一個相對路徑。
3。__FUNCTION__
返回函數名稱(PHP 4.3.0 新加)。自 PHP 5 起本常量返回該函數被定義時的名字(區分大小寫)。在 PHP 4 中該值總是小寫字母的。
4。__CLASS__
返回類的名稱(PHP 4.3.0 新加)。自 PHP 5 起本常量返回該類被定義時的名字(區分大小寫)。在 PHP 4 中該值總是小寫字母的。
5。__METHOD__
返回類的方法名(PHP 5.0.0 新加)。返回該方法被定義時的名字(區分大小寫)。
三:魔術函數執行個體
1.__construct() 當執行個體化一個對象的時候,這個對象的這個方法首先被調用。
class Test { function __construct() { echo "before"; } } $t = new Test(); |
輸出是:start
我們知道php5物件模型 和類名相同的函數是類的建構函式,那麼如果我們同時定義建構函式和__construct()方法的話,php5會預設調用建構函式而不會調用__construct()函數,所以__construct()作為類的預設的建構函式
2.__destruct() 當刪除一個對象或對象操作終止的時候,調用該方法。
class Test { function __destruct() { echo "end"; } } $t = new Test(); 將會輸出 end |
我們就可以在對象操作結束的時候進行釋放資源之類的操作
3.__get() 當試圖讀取一個並不存在的屬性的時候被調用。
如果試圖讀取一個對象並不存在的屬性的時候,PHP就會給出錯誤資訊。如果在類裡添加__get方法,並且我們可以用這個函數實作類別似java中反射的各種操作。
class Test { public function __get($key) { echo $key . " 不存在"; } }
$t = new Test(); echo $t->name;
就會輸出: name 不存在 |
4.__set() 當試圖向一個並不存在的屬性寫入值的時候被調用。
class Test { public function __set($key,$value) { echo '對'.$key . "附值".$value; } }
$t = new Test(); $t->name = "aninggo";
就會輸出: 對 name 附值 aninggo |
5.__call() 當試圖調用一個對象並不存在的方法時,調用該方法。
class Test { public function __call($Key, $Args) { echo "您要調用的 {$Key} 方法不存在。你傳入的參數是:" . print_r($Args, true); } }
$t = new Test(); $t->getName(aning,go); |
程式將會輸出:
您要調用的 getName 方法不存在。參數是:Array
(
[0] => aning
[1] => go
)
6.__toString() 當列印一個對象的時候被調用
這個方法類似於java的toString方法,當我們直接列印對象的時候回調用這個函數
class Test { public function __toString() { return "列印 Test"; } }
$t = new Test();
echo $t; |
運行echo $t;的時候,就會調用$t->__toString();從而輸出
列印 Test
7.__clone() 當對象被複製時,被調用
class Test
{
public function __clone()
{
echo "我被複製了!";
}
}
$t = new Test();
$t1 = clone $t;
程式輸出:我被複製了!
四.順便介紹下php5中提供的幾個非常COOl的實驗性函數
(1)runkit_method_rename
這個函數可以動態改變我們所調用的函數的名字。
class Test {
function foo() { return "foo! "; }
}
runkit_method_rename( 'Test', //類名 'foo',//實際調用的函數 'bar'//顯示調用的函數 );
echo Test::bar();
程式將輸出 foo! |
(2) runkit_method_add
這個函數可以動態向類中添加函數
class Test {
function foo() { return "foo! "; }
}
runkit_method_add( Test, //類名 'add', //新函數名 '$num1, $num2',//傳入參數 'return $num1 + $num2;',//執行的代碼 RUNKIT_ACC_PUBLIC );
// 調用 echo $e->add(12, 4); |
(3)runkit_method_copy
可以把A類中的函數拷貝到類B中並對函數重新命名
class Foo { function example() { return "foo! "; } }
class Bar { //空類 }
//執行拷貝 runkit_method_copy('Bar', 'baz', 'Foo', 'example');
//執行拷貝後的函數 echo Bar::baz(); |
(4) runkit_method_redefine
動態修改函數的傳回值
這個函數可以讓我們輕鬆的實現對類的MOCK測試!是不是很COOL呢
class Example { function foo() { return "foo! "; } }
//建立一個測試對象 $e = new Example();
// 在測試對象之前輸出 echo "Before: " . $e->foo();
// 修改傳回值 runkit_method_redefine( 'Example', 'foo', '', 'return "bar! ";', RUNKIT_ACC_PUBLIC );
// 執行輸出 echo "After: " . $e->foo(); |
(5)runkit_method_remove
這個函數就很簡單了,看名字就能看出來了,動態從類中移除函數
class Test { function foo() { return "foo! "; } function bar() { return "bar! "; } } // 移除foo函數 runkit_method_remove( 'Test', 'foo' ); echo implode(' ', get_class_methods('Test')); 程式輸出 bar