




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、-. z.實(shí)驗四 派生類與繼承【實(shí)驗類型】驗證性實(shí)驗 【實(shí)驗課時】2學(xué)時 【實(shí)驗?zāi)康摹? 理解類的繼承的概念,能夠定義和使用類的繼承關(guān)系。2 掌握派生類的聲明與定義方法。3 熟悉公有派生和私有派生的訪問特性。4 學(xué)習(xí)虛基類在解決二義性問題中的作用?!緦?shí)驗環(huán)境】硬件:計算機(jī)軟件:Microsoft Visual C+ 6.0【實(shí)驗容】1、按要求閱讀、編寫、調(diào)試和運(yùn)行以下程序。(1)實(shí)驗容定義一個基類MyArray,基類中可以存放一組整數(shù)。class MyArraypublic: MyArray(int leng); MyArray(); void Input(); void Display();
2、protected:long int *alist; / 指向動態(tài)申請的一組空間int length; / 整數(shù)的個數(shù)基類中有構(gòu)造函數(shù)、析構(gòu)函數(shù)、輸入數(shù)據(jù)和輸出數(shù)據(jù)的函數(shù)。定義一個類SortArray繼承自MyArray ,在該類中定義函數(shù)實(shí)現(xiàn)排序功能。定義一個類ReArray繼承自MyArray ,在該類中定義函數(shù)實(shí)現(xiàn)逆轉(zhuǎn)功能。定義一個類AverArray繼承自MyArray ,在該類中定義函數(shù)Aver求解整數(shù)的平均值。定義NewArray類,同時繼承了SortArray, ReArray和AverArray,使得NewArray類的對象同時具有排序、逆轉(zhuǎn)、和求平均值的功能。在繼承的過程中聲
3、明為虛基類,體會虛基類在解決二義性問題中的作用。2實(shí)驗程序 (參考)程序如下:#include iostream.h#include process.hclass MyArraypublic: MyArray(int leng); MyArray(); void Input(); void Display();protected:long int *alist; / 指向動態(tài)申請的一組空間int length; / 整數(shù)的個數(shù);MyArray:MyArray(int leng)length=leng; alist=new long intlength; if(alist=NULL) cout對
4、不起,創(chuàng)立失敗。請重試。;e*it(1); MyArray:MyArray() delete alist; cout數(shù)組被清空。endl; void MyArray:Display() / 顯示數(shù)組容 int i; long int *p=alist; for (i=0;ilength;i+,p+) cout *p;void MyArray:Input() / 從鍵盤假設(shè)干整數(shù) cout請輸入:length個整數(shù):; int i; long int *p=alist; for(i=0;i*p;class SortArray:virtual public MyArray private: int
5、 len; long int *sp;public: SortArray(int leng):MyArray(leng) len=leng; Sort(); ; void Sort() sp=new long intlen;long int q;sp=alist;for(int i=0;ilen;i+) for(int j=0;j*(sp+j+1) q=*(sp+j); *(sp+j)=*(sp+j+1); *(sp+j+1)=q; ;class ReArray:virtual public MyArray / 這里是虛基類,public: void Reverse() rp=new long
6、 intlen; long int q; rp=alist;for(int i=0;ilen/2;i+)q=*(rp+i); *(rp+i)=*(rp+len-i-1); *(rp+len-i-1)=q; ReArray(int leng):MyArray(leng) len=leng; Reverse(); private: int len; long int *rp;class AverArray:virtual public MyArray / 這里是虛基類,public: double Aver() ap=new long intlen; double q=0; ap=alist; f
7、or(int i=0;ilen;i+) q=q+*ap;ap+; q=q/len; return q; AverArray(int leng):MyArray(leng) len=leng; private:int len;long int *ap;class NewArray:public ReArray,public SortArray,public AverArray public: NewArray(int leng); NewArray();NewArray:NewArray(intleng):MyArray(leng),SortArray(leng),ReArray(leng),A
8、verArray(leng) coutn新數(shù)組正在創(chuàng)立。n;NewArray:NewArray() coutn新數(shù)組已被清空。n;void main() char b; int leng; do cout請輸入數(shù)組長度:leng; while(leng=0) coutleng; coutn開場:n; NewArray n(leng); n.Input(); coutn您輸入的數(shù)組為:endl; n.Display(); / 顯示數(shù)組 n.Reverse(); /顯示逆序 coutn倒序數(shù)組為:endl; n.Display(); / 顯示逆轉(zhuǎn)以前的情況 coutn平均值是:n.Aver()en
9、dl;/求平均值 n.Sort(); /排序 coutn排序后從小到大數(shù)組為:endl; n.Display(); / 顯示排序以后的情況 coutnA繼續(xù) Q退出b; while(b=A|b=a);執(zhí)行結(jié)果為:2、編寫一個學(xué)生和教師數(shù)據(jù)輸入和顯示程序。1實(shí)驗容編寫學(xué)生和教師數(shù)據(jù)輸入和顯示程序,學(xué)生數(shù)據(jù)有編號、班號和成績,教師數(shù)據(jù)有編號、職稱和部門。要求將編號、輸入和顯示設(shè)計成一個類person,并作為學(xué)生數(shù)據(jù)操作類student和教師數(shù)據(jù)操作類teacher的基類。2實(shí)驗程序參考#includeclass person protected:int m;char A20;char *name;
10、 public:void input()coutm;coutA; name=&A0; void display() cout編號:mendl;cout:nameendl; ; class student:public person protected: int classnum, mark;public: void input1() cout輸入一個學(xué)生數(shù)據(jù):endl;input();coutclassnum;coutmark; void display1()cout顯示一個學(xué)生的數(shù)據(jù):endl;display();cout班號:classnumendl;cout成績:markendl; ;c
11、lass teacher: public personprotected: char zhicheng20,bumen20; char *p; public: void input2() cout顯示一個教師的數(shù)據(jù):endl; input(); coutzhicheng; coutbumen; void display2() cout顯示一個教師的數(shù)據(jù):endl; display(); p=&zhicheng0;cout職稱:pendl; p=&bumen0; cout部門:pendl; ; void main() student S;teacher T; S.input1(); T.input2(); S.display1(); T.display2(); 【實(shí)驗提示】繼承是面向?qū)ο蟪绦蛟O(shè)計的一個重要特性,它允許在已有類的根底上創(chuàng)立新的類,新類可以從一個或多個既有類中繼承函數(shù)和數(shù)據(jù),而且可以重新定義或加進(jìn)新的數(shù)據(jù)和函數(shù),從而形成類的層次或等級。實(shí)驗1中著重時在這方面進(jìn)展練習(xí),除了需要熟練掌握派生類的聲明和定義,還需要靈活運(yùn)用公有派生和私有派生來解決實(shí)際問題。虛基類用于想把公共的基類只產(chǎn)生一個拷貝時,它的初始化與一般的多繼承的初始化在語法上是一樣的,但是構(gòu)造函數(shù)的調(diào)用順序不同。C+編程中派生類可以被基類指針引用,這叫向后兼容,可以提高程序的可擴(kuò)大性
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 西安職業(yè)技術(shù)學(xué)院《軟件設(shè)計V:軟件工程導(dǎo)論》2023-2024學(xué)年第二學(xué)期期末試卷
- 南通大學(xué)《小學(xué)心理輔導(dǎo)設(shè)計》2023-2024學(xué)年第二學(xué)期期末試卷
- 新鄉(xiāng)工程學(xué)院《大數(shù)據(jù)挖掘及應(yīng)用》2023-2024學(xué)年第二學(xué)期期末試卷
- 宜昌科技職業(yè)學(xué)院《晶體光學(xué)實(shí)驗》2023-2024學(xué)年第二學(xué)期期末試卷
- 四川體育職業(yè)學(xué)院《電工電子》2023-2024學(xué)年第二學(xué)期期末試卷
- 西安理工大學(xué)《虛擬儀器實(shí)踐》2023-2024學(xué)年第二學(xué)期期末試卷
- 西安科技大學(xué)《實(shí)驗診斷學(xué)見習(xí)》2023-2024學(xué)年第二學(xué)期期末試卷
- 廣州美術(shù)學(xué)院《外科護(hù)理學(xué)(Ⅱ)》2023-2024學(xué)年第二學(xué)期期末試卷
- 中華女子學(xué)院《電子商務(wù)基礎(chǔ)與應(yīng)用》2023-2024學(xué)年第二學(xué)期期末試卷
- (高清版)DBJ 08-56-1996 建筑幕墻工程技術(shù)規(guī)程(玻璃幕墻分冊)
- 2024全國初中數(shù)學(xué)競賽試題及答案
- 學(xué)術(shù)期刊數(shù)字化轉(zhuǎn)型-深度研究
- 新版院感培訓(xùn)課件
- (高清版)DB36∕T 1332-2020 水利工程標(biāo)識標(biāo)牌
- 臺安N2變頻器說明書
- 浙江寧波鎮(zhèn)海區(qū)2025屆中考生物對點(diǎn)突破模擬試卷含解析
- 2025屆八省聯(lián)考語文試卷評析及備考策略 課件
- 脫硫塔拆除施工方案
- 北京二十中2025屆高考英語二模試卷含解析
- 《高速公路電動汽車清障救援作業(yè)規(guī)范》
- 五年級下冊異分母分?jǐn)?shù)加減法練習(xí)200題有答案
評論
0/150
提交評論