《C++面向?qū)ο蟪绦蛟O(shè)計(jì)》期末考試試題(共7頁)

上傳人:2127513****773577... 文檔編號(hào):58676890 上傳時(shí)間:2022-02-28 格式:DOC 頁數(shù):7 大小:55.50KB
收藏 版權(quán)申訴 舉報(bào) 下載
《C++面向?qū)ο蟪绦蛟O(shè)計(jì)》期末考試試題(共7頁)_第1頁
第1頁 / 共7頁
《C++面向?qū)ο蟪绦蛟O(shè)計(jì)》期末考試試題(共7頁)_第2頁
第2頁 / 共7頁
《C++面向?qū)ο蟪绦蛟O(shè)計(jì)》期末考試試題(共7頁)_第3頁
第3頁 / 共7頁

下載文檔到電腦,查找使用更方便

20 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《《C++面向?qū)ο蟪绦蛟O(shè)計(jì)》期末考試試題(共7頁)》由會(huì)員分享,可在線閱讀,更多相關(guān)《《C++面向?qū)ο蟪绦蛟O(shè)計(jì)》期末考試試題(共7頁)(7頁珍藏版)》請?jiān)谘b配圖網(wǎng)上搜索。

1、精選優(yōu)質(zhì)文檔-----傾情為你奉上 《C++面向?qū)ο蟪绦蛟O(shè)計(jì)》考試試題 2 本試卷滿分100分; 2 請將答案寫在答題紙上,寫明題號(hào),不必抄題,字跡工整、清晰; 2 請?jiān)诖痤}紙和試題紙上都寫上你的班級(jí),學(xué)號(hào)和姓名,交卷時(shí)請將試題紙、答題紙和草紙 一并交上來。 一、 單選題(共10分,每題1分) 1. C++中解決命名沖突的機(jī)制是:D (A) 虛基類 (B) 虛函數(shù) (C) 函數(shù)重載 (D) 名字空間 2. 若類A的一個(gè)對(duì)象所占的內(nèi)存空間中包含虛函數(shù)表的入口地址,則: C (A) 類A不能有靜態(tài)數(shù)據(jù)成員       (B) 類A中公有的成員函

2、數(shù)一定是虛的 (C) 類A中至少有一個(gè)成員函數(shù)是虛的   (D) 類A的析構(gòu)函數(shù)一定是虛的 3.任意一個(gè)類,析構(gòu)函數(shù)的個(gè)數(shù)最多是:B (A) 不限個(gè)數(shù) (B) 1 (C) 2 (D) 3 4. 下列關(guān)于this指針的說法,哪個(gè)是正確的: D (A) this指針一定指向常量型數(shù)據(jù) (B) this指向的數(shù)據(jù)不可更改 (C) 靜態(tài)成員函數(shù)中也可以訪問this指針 (D) this指針本身可直接作為成員函數(shù)的返回值 5.在類定義中,為說明成員的訪問權(quán)限,private, protected, public 可以出現(xiàn)次數(shù)為:

3、A (A)次數(shù)沒有具體限定 (B) 每種至多一次 (C) public 至少一次 (D) 每種至少一次 6.下面哪種定義方式是正確的,并且使得p可以作為函數(shù)void f( A* const pp);的實(shí)參:A (A) A * p = new A; (B) A a; A* p = a; (C) const A* p = new A; (D) A a; const A* p = a; 7. obj是類A的一個(gè)對(duì)象,執(zhí)行語句 const A& aA= obj; ,則下列說法正確的是

4、: C (A) 類A的拷貝構(gòu)造函數(shù)會(huì)被調(diào)用 (B) 類A的賦值函數(shù)會(huì)被調(diào)用 (C) &aA的值就是 &obj (D) 語句obj.f( );等價(jià)于語句aA.f( ); 8.下面關(guān)于訪問類A的私有數(shù)據(jù)成員的說法,錯(cuò)誤的是: C (A) 類A的友元函數(shù)可以訪問類A的私有成員。 (B) 類A的友元類中的非靜態(tài)成員函數(shù)可以訪問類A的私有成員。 (C) 類A的嵌套類中的非靜態(tài)成員函數(shù)可以訪問類A的私有成員。 (D) 類A中的非靜態(tài)成員函數(shù)可以訪問類A的私有成員。 9.類A中有唯一的一個(gè)成員函數(shù)f,且f是公有的靜態(tài)或非靜態(tài)成員函數(shù),對(duì)于類A的一個(gè)對(duì)象a,執(zhí)行

5、語句 a.f(100);成功,那么f 的函數(shù)原型不可以是:B (A) A& f( int, int=50 ); (B) void f(int& ) ; (C) const A * f(const int ); (D) A f( const int&); 10. 下面關(guān)于類的成員函數(shù)描述不正確的是:A (A) 靜態(tài)成員函數(shù)內(nèi)可以直接訪問類的非靜態(tài)成員數(shù)據(jù) (B) 靜態(tài)成員函數(shù)內(nèi)可以直接訪問類的靜態(tài)成員數(shù)據(jù) (C) 非靜態(tài)成員函數(shù)可以直接訪問類的非靜態(tài)成員數(shù)據(jù) (D) 非靜態(tài)成員函數(shù)可以直接訪問類的靜態(tài)成員數(shù)據(jù)(全局成員) 二

6、、判斷正誤,對(duì)于你認(rèn)為錯(cuò)誤的論述,說明原因或舉出反例。(每題2分,共20分) 1. 重載流操作符<<和>> 時(shí),如果第一個(gè)參數(shù)的類型為ostream 和istream,那么這個(gè)重載函數(shù)既可以用于標(biāo)準(zhǔn)輸入輸出流,也可以用于文件流上。 對(duì),ostream 和istream是標(biāo)準(zhǔn)輸入輸出流、文件流、字符串流的基類 2. 在同一個(gè)類中,可以定義重載的成員函數(shù) void f(int);和virtual void f(int); 。 錯(cuò),這屬于重復(fù)定義 3. 抽象類不會(huì)產(chǎn)生實(shí)例,所以不需要有構(gòu)造函數(shù)。 錯(cuò),被派生時(shí)需要它的構(gòu)造函數(shù) 4. 類A有一個(gè)非靜態(tài)的成員函數(shù)f,其函數(shù)原型是:void

7、A::f( ) const,則該函數(shù)被調(diào)用時(shí),一定是通過類A或類A的某后裔類的一個(gè)用const修飾符說明的常量對(duì)象調(diào)用的。 錯(cuò),常函數(shù)可以由變量對(duì)象或常量對(duì)象調(diào)用 5. 異常必須在其產(chǎn)生的當(dāng)前函數(shù)中捕獲,而不能在外層函數(shù)中捕獲該異常。 錯(cuò),可以在外層捕獲,并且這是最常見的用法 6. 只要程序中沒有A a1 = a2; 和A a1(a2); 形式的代碼,類A的拷貝構(gòu)造函數(shù)就不會(huì)被調(diào)用。 錯(cuò),參數(shù)傳遞或函數(shù)返回時(shí)也調(diào)用拷貝構(gòu)造函數(shù) 7. 在protected繼承方式下,派生類對(duì)象的指針不能直接轉(zhuǎn)換成指向基類對(duì)象的指針。 對(duì),否則基類中的公有成員由不可見變?yōu)榭梢?,?quán)限被放大 8.

8、 若靜態(tài)成員函數(shù)中調(diào)用了一個(gè)函數(shù)f,那么f 一定不是虛函數(shù)。 對(duì),靜態(tài)成員函數(shù)不能是虛函數(shù),因?yàn)樘摵瘮?shù)入口需要在保存在對(duì)象中的虛函數(shù) 表中,而靜態(tài)成員函數(shù)不屬于對(duì)象。 9. 若要實(shí)例化一個(gè)含有引用型數(shù)據(jù)成員的類,那么只能使用構(gòu)造函數(shù)初始化列表來初始化該數(shù)據(jù)成員。 對(duì),沒有別的辦法 10. 構(gòu)造函數(shù)的函數(shù)體中,不能使用return語句;但在實(shí)現(xiàn)該類的自動(dòng)類型轉(zhuǎn)化函數(shù)時(shí),必須有return 語句。 對(duì) 三、回答下列各題(每題4分,共20分) 1. 舉例說明static關(guān)鍵字的用法和相應(yīng)目的(至少3種)。 f(){ static int a;…} 函數(shù)體內(nèi)的靜態(tài)變量,每次調(diào)用該

9、函數(shù)時(shí)值保持不變 static int a; 全局的靜態(tài)變量,約束作用域?yàn)樗谖募? class A {static int a;…}; A的靜態(tài)成員,類似全局變量,需用A::a訪問 2. 舉例說明類的數(shù)據(jù)成員在哪些情況下必須在初始化列表中進(jìn)行初始化(至少3種)。 基類不提供無參的構(gòu)造函數(shù) 成員對(duì)象不提供無參的構(gòu)造函數(shù) 有常量成員或引用成員 3. 舉例說明虛擬繼承的作用和目的。 虛擬繼承的目的是使基類在派生類中只保留一個(gè)副本 從而避免二義性 4. 舉例說明成員函數(shù)A& f( ) const;和成員函數(shù)A& f( ); 的區(qū)別。 A& f( ) const是常函數(shù),隱含的th

10、is指針是常指針,因此在f中不能修改對(duì)象成員的值。 舉例略 5. 有類A的對(duì)象a,任意給出一種解決方案,使得程序支持下面的表達(dá)式: a=10+a; class A { A(int); //轉(zhuǎn)換構(gòu)造函數(shù) friend const A operator+(const A,const A); //重載+ }; 四、指出下列程序代碼中存在的錯(cuò)誤或不足,說明原因。(每題5分,共10分) 1. #include class A { public: virtual ~A( ) { } virtual void f( ) {

11、 cout<<"A::f( )"<f( ); p->g( ); p->k( );

12、 delete p; } 答:函數(shù)k在A中沒有定義,執(zhí)行p->k( );時(shí)要根據(jù)p的類型在A中查k的信息 2. #include #include class A; class B:public A { public: B(const char* info){ m_buf=new char[256]; strcpy(m_buf,info); } ~B( ) { delete[] m_buf; } virtual void output( ) { cout << m_buf; }

13、 private: char * m_buf; }; class A { public: ~A( ) { } virtual void output( ) { } }; void main() { A*pa = new B("hello!") ; pa->output( ); delete pa; } 答:A的析構(gòu)函數(shù)應(yīng)定義為虛函數(shù),否則B的析構(gòu)函數(shù)不會(huì)被調(diào)用,m_buf也不會(huì)被釋放 五、寫出下面程序的運(yùn)行結(jié)果(每題5分,共10分) 1. #include class A { public: A(

14、):count(1) {} virtual ~A( ) {} virtual A* Copy( ) const = 0; virtual void Out( ) const = 0; protected: int count; }; class B:public A { public: ~B( ) { --count; Out( ); } virtual A* Copy( ) const { B *p = new B(*this); ++p->count; return p;

15、 } virtual void Out( ) const { cout << count << endl; } }; void main( ) { { B b; A* a1=&b; a1->Out( ); a1 = a1->Copy( ); a1->Out( ); delete a1; } } 答: 1 2 1 0 -------------------- 2. #include class A { public: A(int n):num(n) { Out( );

16、 } A(const A& rhs):num(rhs.num) {Out( );} void Out( ) {cout<

17、(b1); b2.Out(); } 答: 8 1 8 1 8 8 ------------- 六、閱讀下面兩個(gè)類的定義和部分實(shí)現(xiàn)代碼,完成3個(gè)問題。(共10分) #include class A { public: A(int n):value(n) { } void Display( ) const {cout<<"Value = "<

18、id Display( ) const { aA.Display(); } private: A aA; }; int main( ) { B b1(1); b1.Display( ); B b2(2); b2. Display( ); return 0; } 1. [3分]實(shí)現(xiàn)類B的構(gòu)造函數(shù),使得程序的輸出為: Value=1 Value=2 答:B(int n):aA(n) 2.[3分]若main函數(shù)中增加了語句B b3(b1); 針對(duì)本例,說明是否有必要以公有方式自定義并實(shí)現(xiàn)類B的拷貝構(gòu)造函數(shù),為什么? 答:不需要,

19、因?yàn)轭怋及基類A中不存在引用或指針成員,使用默認(rèn)的拷貝構(gòu)造函數(shù)就可以。 3. [4分]在不改動(dòng)類A和main函數(shù)的前提下,以繼承的方式重新定義并實(shí)現(xiàn)類B,使得程序的輸出結(jié)果不變。 答: class B:public A { public: B(int n):A(n); void Display( ) const { A::Display(); } }; 七、(共20分,每問題10分) 某程序員為了靈活地對(duì)各種的給定的曲線函數(shù)f(x)畫出其曲線圖形,設(shè)計(jì)并部分實(shí)現(xiàn)了一個(gè)曲線類curve,該類的成員數(shù)據(jù)中,count代表坐標(biāo)點(diǎn)的個(gè)數(shù),pxs代表的數(shù)組存放這些坐標(biāo)點(diǎn)的橫坐

20、標(biāo),pys代表的數(shù)組存放利用f(x)計(jì)算得到的這些坐標(biāo)點(diǎn)的縱坐標(biāo)。由于不同曲線的計(jì)算公式f(x)是不同的,該程序員希望曲線函數(shù)的種類可以通過繼承curve類的方式任意增加,增加一個(gè)新的f(x)時(shí)不改變curve類中的內(nèi)容,也不改變利用curve類進(jìn)行圖形繪制的算法。已部分完成的curve類定義和實(shí)現(xiàn)如下: class curve { public: void setPxs( ) {/*把獲取的橫坐標(biāo)數(shù)據(jù)存放在pxs代表的數(shù)組中,并為count置值*/ } double* getPxs( ) const { return pxs;} int getCount( ) const

21、 { return count;} double* getPys( ) const ; private: double* pxs; double* pys; int count }; 1、請按照該程序員的設(shè)計(jì)意圖給出成員函數(shù)getPys的完整實(shí)現(xiàn)。實(shí)現(xiàn)過程中,可以為curve類增加其它成員。可以假設(shè)setPxs函數(shù)已經(jīng)完整實(shí)現(xiàn),不需要考慮曲線的繪制和顯示。 答: class curve { public: void setPxs( ) {/*把獲取的橫坐標(biāo)數(shù)據(jù)存放在pxs代表的數(shù)組中,并為count置值*/ } double* getPxs( ) con

22、st { return pxs;} int getCount( ) const { return count;} double* getPys( ) const ; virtual double f(double)=0; private: double* pxs; double* pys; int count }; double* curve::getPys( ) const { if(pys==NULL) pys=new double[count]; for(int i=0;i

展開閱讀全文
溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號(hào):ICP2024067431號(hào)-1 川公網(wǎng)安備51140202000466號(hào)


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺(tái),本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!