ARRAY&operator=(constARRAY&a);
friendARRAYoperator+(ARRAY&a,ARRAY&b);
friendostream&operator<<(ostream&os,ARRAY&a); };
ARRAY::ARRAY(constARRAY&a)
{ //**2**
for(inti=0;i
p[i]=a.p[i]; }
int&ARRAY::operator[](inti)
{ //**3**
{ cout<<"越界訪問!";
exit(0); }
returnp[i]; }
ARRAY&ARRAY::operator=(constARRAY&a)
{ num=a.num;
p=newint[num];
for(inti=0;i
p[i]=a.p[i];
//**4** }
ARRAYoperator+(ARRAY&a,ARRAY&b)
{ if(a.num!=b.num)
{ cout<<"數(shù)組長度不相同!"<
exit(0); }
ARRAYt(a.num);
for(inti=0;i
t.p[i]=a.p[i]+b.p[i];
returnt; }
ostream&operator<<(ostream&os,ARRAY&a)
{ inti=0;
for(;i
{ cout<
if(!((i+1)%10))cout<
returnos; }
voidmain()
{ ARRAYa(3);
a[0]=a[1]=a[2]=3;
ARRAYb(a);
cout<<'b'<
ARRAYc(2);
c=a+b+b;
cout<<'c'<
c=((b=(a+b))+c);
a[7]=3;
【參考答案】
(1)if(i<=0)
(2)num=a.num;
p=new int[num];
(3)if(i>=num||i<0)
(4)return *this;
【試題解析】
主要考查對一個特殊的類--安全數(shù)組的掌握,其中涉及了友元函數(shù)、重載函數(shù)等,其中(2)中必需申請新的空間,這樣可以使得兩個對象分別占用不同的兩個空間,在自動調(diào)用析構(gòu)函數(shù)時不會遇到重復(fù)刪除的問題,這種方法要掌握。
相關(guān)推薦:2010年9月計算機(jī)等級考試精華備考資料匯總北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |