首頁 >後端開發 >PHP問題 >建構函數與析構函數的原理分析

建構函數與析構函數的原理分析

王林
王林轉載
2020-07-10 17:56:492989瀏覽

建構函數與析構函數的原理分析

建構子

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

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

(推薦教學:php教學

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

程式碼範例:

<?php
class BaseClass {
  function __construct() {
    print "In BaseClass constructor\n";
  }
}

class SubClass extends BaseClass {
  function __construct() {
    parent::__construct();
    print "In SubClass constructor\n";
  }
}

class OtherSubClass extends BaseClass {
  // inherits BaseClass&#39;s constructor
}

// In BaseClass constructor
$obj = new BaseClass();

// In BaseClass constructor
// In SubClass constructor
$obj = new SubClass();

// In BaseClass constructor
$obj = new OtherSubClass();
?>

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

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

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

程式碼範例:

<?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
  }
}

析構函數

__destruct ( void ) : void

PHP 5 引入了析構函數的概念,這類似於其它面向對象的語言,如C 。析構函數會在某個物件的所有參考都被刪除或當物件被明確銷毀時執行。

程式碼範例:

<?php
class MyDestructableClass {
  function __construct() {
    print "In constructor\n";
    $this->name = "MyDestructableClass";
  }

  function __destruct() {
    print "Destroying " . $this->name . "\n";
  }
}

$obj = new MyDestructableClass();

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

析構函數即使在使用 exit() 終止腳本執行時也會被呼叫。在析構函數中呼叫 exit() 將會中止其餘關閉操作的運作。

以上是建構函數與析構函數的原理分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:jb51.net。如有侵權,請聯絡admin@php.cn刪除