簡介
構造函數是一種特殊的方法主要用來在創建對象時初始化對象即為對象成員變量賦初始值總與new運算符一起使用,在創建對象的語句中特别的一個類可以有多個構造函數,可根據其參數個數的不同或參數類型的不同來區分它們即構造函數的重載。
構造函數與其他方法的區别
1、構造函數的命名必須和類名完全相同;而一般方法則不能和類名相同。
2、構造函數的功能主要用于在類的對象創建時定義初始化的狀态。它沒有返回值,也不能用void來修飾。這就保證了它不僅什麼也不用自動返回,而且根本不能有任何選擇。而其他方法都有返回值。即使是void返回值,盡管方法體本身不會自動返回什麼,但仍然可以讓它返回一些東西,而這些東西可能是不安全的。
3、構造函數不能被直接調用,必須通過new運算符在創建對象時才會自動調用,一般方法在程序執行到它的時候被調用。
4、當定義一個類的時候,通常情況下都會顯示該類的構造函數,并在函數中指定初始化的工作也可省略,不過Java編譯器會提供一個默認的構造函數。此默認構造函數是不帶參數的。而一般方法不存在這一特點。
5、當一個類隻定義了私有的構造函數,将無法通過new關鍵字來創建其對象,當一個類沒有定義任何構造函數,C#編譯器會為其自動生成一個默認的無參的構造函數。
C++中的構造函數
C++的構造函數定義格式為:構造函數
class<類名>
public:
<類名>(參數表)
//...(還可以聲明其它成員函數)
<類名>::<類名>(參數表)
//函數體
如以下定義是合法的:
class T
public:
T(int a=0){i=a;}//構造函數允許直接寫在類定義内,也允許有參數表。
private:int i;
當程序中沒有析構函數時,系統會自動生成以下構造函數:
<類名>::<類名>(){},即不執行任何操作。
C++例子
//注意若将本代碼直接複制進編譯器,可能會報錯,原因是網頁生成時會在代碼前加一個中文占位符
//最好将代碼再寫一次
#include
using namespace std;
class time
public:
time() //constructor.構造函數
hour=0;
minute=0;
sec=0;
void set_time();
void show_time();
private:
int hour;
int minute;
int sec;
int main();
class time t1;
t1.show_time();
t1.set_time();
t1.show_time();
return 0;
void time::set_time()
cin >>hour;
cin >>minute;
cin >>sec;
void time::show_time()
{ cout<}
程序運行情況:
0:0:0
10 11 11 回車
10:11:11
任何時候,隻要創建類或結構,就會調用它的構造函數。類或結構可能有多個接受不同參數的構造函數。構造函數使得程序員可設置默認值、限制實例化以及編寫靈活且便于閱讀的代碼。
JAVA示例代碼:
public class UserManagerImpl implements UserManager
private UserDao userDao;
public UserManagerImpl(UserDao userDao)
this.userDao=userDao;
public void save(String username,String password)
this.userDao.save(username, password);
PHP中的構造函數
構造函數的聲明與其它操作的聲明一樣,隻是其名稱必須是兩個下劃線__construct( )。這是PHP5中的變化;PHP4的版本中,構造函數的名稱必須與類名相同。為了向下兼容,如果一個類中沒有名為__construct( )的方法,PHP将搜索一個與類名相同的方法。
格式:function __construct ( [參數] ) { ... ... }
例子:
class person{
public $name;
public $age;
function _ _construct(){ // 構造函數
$this->name="lisi";
$this->age=28;
function say()
echo "my name is ".$this->name."
echo "my age is ".$this->age."
$per=new person();
$per->say();
$per->name="zhangsan";
$per->age=26;
$per->say();
C#例子
構造函數是在創建給定類型的對象時執行的類方法。構造函數具有與類相同的名稱,它通常初始化新對象的數據成員。
在下面的示例中,使用一個簡單的構造函數定義了名為Taxi的類。然後使用new運算符來實例化該類。在為新對象分配内存之後,new運算符立即調用Taxi構造函數。
public class Taxi{ public bool isInitialized; public Taxi() { isInitialized = true; }}class TestTaxi{ static void Main() { Taxi t = new Taxi(); System.Console.WriteLine(t.isInitialized); }}
PHP 構造
構造函數
void __construct ( [mixed args [, ...]] )
php 5 允行開發者在一個類中定義一個方法作為構造函數。具有構造函數的類會在每次創建對象時先調用此方法,所以非常适合在使用對象之前做一些初始化工作。
注:如果子類中定義了構造函數則不會暗中調用其父類的構造函數。要執行父類的構造函數,需要在子類的構造函數中調用parent::__construct()。
例子 19-6. 使用新标準的構造函數
class BaseClass
function __construct()
print "In BaseClass constructor
class SubClass extends BaseClass
function __construct()
parent::__construct();
print "In SubClass constructor/n";
$obj = new BaseClass();
$obj = new SubClass(); ?>
為了實現向後兼容性,如果 php 5 在類中找不到__construct()函數,它就會嘗試尋找舊式的構造函數,也就是和類同名的函數。因此唯一會産生兼容性問題的情況是:類中已有一個名為__construct()的方法,但它卻又不是構造函數。
析構函數
void __destruct ( void )
php 5 引入了析構函數的概念,這類似于其它面向對象的語言,如C++。析構函數會在到某個對象的所有引用都被删除或者當對象被顯式銷毀時執行。
例子 19-7. 析構函數示例
class MyDestructableClass
function __construct()
print "In constructor/n";
$this->name = "MyDestructableClass";
function __destruct()
print "Destroying " . $this->name . "/n";
$obj = new MyDestructableClass();
?>和構造函數一樣,父類的析構函數不會被引擎暗中調用。要執行父類的析構函數,必須在子類的析構函數體中顯式調用parent::__destruct()。
注:析構函數在腳本關閉時調用,此時所有的頭信息已經發出。
注:試圖在析構函數中抛出一個異常會導緻緻命錯誤。



















