簡單介紹php建構函式用法

才智咖 人氣:1.13W

建構函式意思就是在類執行時通過建構函式作為入口進行操作了,下面我們來看一篇關於PHP建構函式用法文章吧。

簡單介紹php建構函式用法

建構函式 和 解構函式

建構函式

void __construct ([ mixed $args [, $... ]] )

PHP 5 允行開發者在一個類中定義一個方法作為建構函式。具有建構函式的類會在每次建立新物件時先呼叫此方法,所以非常適合在使用物件之前做一些初始化工作。

Note: 如果子類中定義了建構函式則不會隱式呼叫其父類的建構函式。要執行父類的建構函式,需要在子類的建構函式中呼叫 parent::__construct()。如果子類沒有定義建構函式則會如同一個普通的類方法一樣從父類繼承(假如沒有被定義為 private 的話)。

Example #1 使用新標準的建構函式

<?php

class BaseClass {

//我是一個父親的建構函式

function __construct() {

print "In BaseClass constructor<br>";

}

}

//我是一個孩子類

class SubClass extends BaseClass {

function __construct() {//孩子的建構函式

parent::__construct(); //我執行一次父親的建構函式先。

print "In SubClass constructor<br>";

}

}

//我是個孩子,但是我沒有自己的建構函式,所以我自動用我父親的

class OtherSubClass extends BaseClass {

// inherits BaseClass's constructor

}

//我是個孩子,我有自己的建構函式,拋棄父親的。所以我不執行父親的建構函式的列印

class OtherSub2Class extends BaseClass {

// inherits BaseClass's constructor

function __construct() {//孩子的建構函式

print "In OtherSub2Class constructor<br>";

}

}

// In BaseClass constructor

$obj = new BaseClass();

// In BaseClass constructor

// In SubClass constructor

$obj = new SubClass();

// In BaseClass constructor

$obj = new OtherSubClass();

$obj = new OtherSub2Class();

?>

為了實現向後相容性,如果 PHP 5 在類中找不到 __construct() 函式並且也沒有從父類繼承一個的話,它就會嘗試尋找舊式的建構函式,也就是和類同名的`函式。因此唯一會產生相容性問題的情況是:類中已有一個名為 __construct()的方法卻被用於其它用途時。

與其它方法不同,當 __construct() 被與父類 __construct() 具有不同引數的方法覆蓋時,PHP 不會產生一個 E_STRICT錯誤資訊。

自 PHP 5.3.3 起,在名稱空間中,與類名同名的方法不再作為建構函式。這一改變不影響不在名稱空間中的類。

Example #2 Constructors in namespaced classes

<?php

namespace Foo;

class Bar {

public function Bar() {

// treated as constructor in PHP 5.3.0-5.3.2

// treated as regular method as of PHP 5.3.3

}

}

?>

解構函式

void __destruct ( void )

PHP 5 引入了解構函式的概念,這類似於其它物件導向的語言,如 C++。解構函式會在到某個物件的所有引用都被刪除或者當物件被顯式銷燬時執行。

在 php 檔案完全執行完畢,這個類會進入銷燬,執行一次解構函式,和建構函式,正好相反,建構函式是在建立類的時候進入執行

Example #3 解構函式示例

<?php

class MyDestructableClass {

function __construct() {

print "In constructor<br>";

$this->name = "MyDestructableClass";

}

function __destruct() {

print "Destroying " . $this->name . "<br>";

}

}

$obj = new MyDestructableClass();

echo 'i write something <br>';

?>

輸出

In constructor

i write something

Destroying MyDestructableClass

和建構函式一樣,父類的解構函式不會被引擎暗中呼叫。要執行父類的解構函式,必須在子類的解構函式體中顯式呼叫 parent::__destruct()。此外也和建構函式一樣,子類如果自己沒有定義解構函式則會繼承父類的。

解構函式即使在使用 exit() 終止指令碼執行時也會被呼叫。在解構函式中呼叫 exit() 將會中止其餘關閉操作的執行。

Note:

解構函式在指令碼關閉時呼叫,此時所有的 HTTP 頭資訊已經發出。指令碼關閉時的工作目錄有可能和在 SAPI(如 apache)中時不同。

Note:

試圖在解構函式(在指令碼終止時被呼叫)中丟擲一個異常會導致致命錯誤。