一、類對象數組
類的對象和C++其他數據類型一樣,也可以為其建立數組,數組的表示方法和結構一樣。
#include iostream.h
class Date
{
int mo,da,yr;
public:
Date(int m=0,int d=0, int y=0) { mo=m; da=d; yr=y;}
void display() const { cout< };
int main()
{
Date dates[2];
Date today(12,31,2003);
dates[0]=today;
dates[0].display();
dates[1].display();
return 0;
}
1.類對象數組和默認構造函數
在前面已經說過,不帶參數或者所有參數都有默認值的構造函數叫做默認構造函數。如果類中沒有構造函數,編譯器會自動提供一個什么都不做的公共默認構造函數 。如果類當中至少有一個構造函數,編譯器就不會提供默認構造函數。
如果類當中不含默認構造函數,則無法實例化其對象數組。因為實例花類對象數組的格式不允許用初始化值來匹配某個構造函數的參數表。
上面的程序中,main()函數聲明了一個長度為2的Date對象數組,還有一個包含初始化值的單個Date對象。接著把這個初始化的Date對象賦值給數組中第一個對象,然后顯示兩個數組元素中包含的日期。從輸出中可以看到,第一個日期是有效日期,而第二個顯示的都是0。
當聲明了某個類的對象數組時,編譯器會為每個元素都調用默認構造函數。
下面的程序去掉了構造函數的默認參數值,并且增加了一個默認構造函數。
#include
class Date
{
int mo, da, yr;
public:
Date();
Date(int m,int d,int y) { mo=m; da=d; yr=y;}
void display() const { cout < };
Date::Date()
{
cout < mo=0; da=0; yr=0;
}
int main()
{
Date dates[2];
Date today(12,31,2003);
dates[0]=today;
dates[0].display();
dates[1].display();
return 0;
}
運行程序,輸出為:
Date constructor running
Date constructor running
12/31/2003
0/0/0
從輸出中可以看出,Date()這個默認構造函數被調用了兩次。
2.類對象數組和析構函數
當類對象離開作用域時,編譯器會為每個對象數組元素調用析構函數。
#include iostream.h
class Date
{
int mo,da,yr;
public:
Date(int m=0,int d=0,int y=0) { mo=m; da=d; yr=y;}
~Date() {cout< void display() const {cout< };
int main()
{
Date dates[2];
Date today(12,31,2003);
dates[0]=today;
dates[0].display();
dates[1].display();
return 0;
}
運行程序,輸出為:
12/31/2003
0/0/0
Date destructor running
Date destructor running
Date destructor running
表明析構函數被調用了三次,也就是dates[0],dates[1],today這三個對象離開作用域時調用的。

