版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第第頁c++經(jīng)典面試題及答案
struct成員默認(rèn)訪問權(quán)限為public,而class成員默認(rèn)訪問權(quán)限為private
2.析構(gòu)函數(shù)和虛函數(shù)的用法和作用
析構(gòu)函數(shù)是在對(duì)象生存期結(jié)束時(shí)自動(dòng)調(diào)用的函數(shù),用來釋放在構(gòu)造函數(shù)安排的內(nèi)存。
虛函數(shù)是指被關(guān)鍵字virtual說明的函數(shù),作用是運(yùn)用C++語言的多態(tài)特性
3.全局變量和局部變量有什么區(qū)分?是怎么實(shí)現(xiàn)的?操作系統(tǒng)和編譯器是怎么知道的?
1)全局變量的作用用這個(gè)程序塊,而局部變量作用于當(dāng)前函數(shù)
2)前者在內(nèi)存中安排在全局?jǐn)?shù)據(jù)區(qū),后者安排在棧區(qū)
3)生命周期不同:全局變量隨主程序創(chuàng)建和創(chuàng)建,隨主程序銷毀而銷毀,局部變量在局部函數(shù)內(nèi)部,甚至局部循環(huán)體等內(nèi)部存在,退出就不存在
4)運(yùn)用方式不同:通過聲明后全局變量程序的各個(gè)部分都可以用到,局部變量只能在局部運(yùn)用
4.有N個(gè)大小不等的自然數(shù)(1N),請(qǐng)將它們由小到大排序.要求程序算法:時(shí)間繁復(fù)度為O(n),空間繁復(fù)度為O(1)。
voidsort(inte[],intn)
{
inti;
intt;
for(i=1;i{
t=e[e[i]];
e[e[i]]=e[i];
e[i]=t;
}
}
5.堆與棧的去區(qū)分
A.申請(qǐng)方式不同
Stack由系統(tǒng)自動(dòng)安排,而heap需要程序員自己申請(qǐng),并指明大小。
B.申請(qǐng)后系統(tǒng)的響應(yīng)不同
Stack:只要棧的剩余空間大于申請(qǐng)空間,系統(tǒng)就為程序提供內(nèi)存,否那么將拋出棧溢出異樣
Heap:當(dāng)系統(tǒng)收到程序申請(qǐng)時(shí),先遍歷操作系統(tǒng)中記錄空閑內(nèi)存地址的鏈表,查找第一個(gè)大于所申請(qǐng)空間的堆結(jié)點(diǎn),然后將該結(jié)點(diǎn)從空間結(jié)點(diǎn)鏈表中刪除,并將該結(jié)點(diǎn)的空間安排給程序。另外,大多數(shù)系統(tǒng)還會(huì)在這塊內(nèi)存空間中的首地址處記錄本次安排的大小,以便于delete語句正確釋放空間。而且,由于找到的堆結(jié)點(diǎn)的大小不肯定正好等于申請(qǐng)的大小,系統(tǒng)會(huì)自動(dòng)將多余的那部分重新放入空閑鏈表。
C.申請(qǐng)大小限制的不同
Stack:在windows下,棧的大小是2M(也可能是1M它是一個(gè)編譯時(shí)就確定的常數(shù)),假如申請(qǐng)的空間超過棧的剩余空間時(shí),將提示overflow。因此,能從棧獲得的空間較小。
Heap:堆是向高地址擴(kuò)展的數(shù)據(jù)結(jié)構(gòu),是不連續(xù)的內(nèi)存區(qū)域。這是由于系統(tǒng)是用鏈表來存儲(chǔ)的空閑內(nèi)存地址的,自然是不連續(xù)的,而鏈表的遍歷方向是由低地址向高地址。堆的大小受限于計(jì)算機(jī)系統(tǒng)中有效的虛擬內(nèi)存。由此可見,堆獲得的空間比較敏捷,也比較大。
D.申請(qǐng)效率的比較:
棧由系統(tǒng)自動(dòng)安排,速度較快。但程序員是無法掌握的。
堆是由new安排的內(nèi)存,一般速度比較慢,而且簡單產(chǎn)生內(nèi)存碎片,不過用起來最方便。
另外,在WINDOWS下,最好的方式是用VirtualAlloc安排內(nèi)存,他不是在堆,也不是在棧是徑直在進(jìn)程的地址空間中保留一快內(nèi)存,雖然用起來最不方便。但是速度快,也最敏捷。
E.堆和棧中的存儲(chǔ)內(nèi)容
棧:在函數(shù)調(diào)用時(shí),第一個(gè)進(jìn)棧的是主函數(shù)中后的下一條指令(函數(shù)調(diào)用語句的下一條可執(zhí)行語句)的地址,然后是函數(shù)的各個(gè)參數(shù),在大多數(shù)的C編譯器中,參數(shù)是由右往左入棧的,然后是函數(shù)中的局部變量。留意靜態(tài)變量是不入棧的。當(dāng)本次函數(shù)調(diào)用結(jié)束后,局部變量先出棧,然后是參數(shù),最末棧頂指針指向最開始存的地址,也就是主函數(shù)中的下一條指令,程序由該點(diǎn)繼續(xù)運(yùn)行。
堆:一般是在堆的頭部用一個(gè)字節(jié)存放堆的大小。堆中的詳細(xì)內(nèi)容有程序員安排。
6.含參數(shù)的宏與函數(shù)的優(yōu)缺點(diǎn)
宏:優(yōu)點(diǎn):在預(yù)處理階段完成,不占用編譯時(shí)間,同時(shí),省去了函數(shù)調(diào)用的.開銷,運(yùn)行效率高
缺點(diǎn):不進(jìn)行類型檢查,多次宏替換會(huì)導(dǎo)致代碼體積變大,而且由于宏本質(zhì)上是字符串替換,故可能會(huì)由于一些參數(shù)的副作用導(dǎo)致得出錯(cuò)誤的結(jié)果。
函數(shù):優(yōu)點(diǎn):沒有帶參數(shù)宏可能導(dǎo)致的副作用,進(jìn)行類型檢查,計(jì)算的正確性更有保證。
缺點(diǎn):函數(shù)調(diào)用需要參數(shù)、返回地址等的入棧、出棧開銷,效率沒有帶參數(shù)宏高
PS:宏與內(nèi)聯(lián)函數(shù)的區(qū)分
內(nèi)聯(lián)函數(shù)和宏都是在程序涌現(xiàn)的地方開展,內(nèi)聯(lián)函數(shù)不是通過函數(shù)調(diào)用實(shí)現(xiàn)的,是在調(diào)用該函數(shù)的程序處將它開展(在編譯期間完成的);宏同樣是;
不同的是:內(nèi)聯(lián)函數(shù)可以在編譯期間完成諸如類型檢測(cè),語句是否正確等編譯功能;宏就不具有這樣的功能,而且宏開展的時(shí)間和內(nèi)聯(lián)函數(shù)也是不同的(在運(yùn)行期間開展)
7.Windows程序的入口是哪里?寫出Windows消息機(jī)制的流程
Windows程序的入口是WinMain()函數(shù)。
Windows應(yīng)用程序消息處理機(jī)制:
A.操作系統(tǒng)接收應(yīng)用程序的窗口消息,將消息投遞到該應(yīng)用程序的消息隊(duì)列中
B.應(yīng)用程序在消息循環(huán)中調(diào)用GetMessage函數(shù)從消息隊(duì)列中取出一條一條的消息,取出消息后,應(yīng)用程序可以對(duì)消息進(jìn)行一些預(yù)處理。
C.應(yīng)用程序調(diào)用DispatchMessage,將消息回傳給操作系統(tǒng)。
D.系統(tǒng)利用WNDCLASS結(jié)構(gòu)體的lpfnWndProc成員保存的窗口過程函數(shù)的指針調(diào)用窗口過程,對(duì)消息進(jìn)行處理。
8.如何定義和實(shí)現(xiàn)一個(gè)類的成員函數(shù)為回調(diào)函數(shù)
A.什么是回調(diào)函數(shù)?
簡而言之,回調(diào)函數(shù)就是被調(diào)用者回頭調(diào)用調(diào)用者的函數(shù)。
運(yùn)用回調(diào)函數(shù)事實(shí)上就是在調(diào)用某個(gè)函數(shù)(通常是API函數(shù))時(shí),將自己的一個(gè)函數(shù)(這個(gè)函數(shù)為回調(diào)函數(shù))的地址作為參數(shù)傳遞給那個(gè)被調(diào)用函數(shù)。而該被調(diào)用函數(shù)在需要的時(shí)候,利用傳遞的地址調(diào)用回調(diào)函數(shù)。
回調(diào)函數(shù),就是由你自己寫的,你需要調(diào)用另外一個(gè)函數(shù),而這個(gè)函數(shù)的其中一個(gè)參數(shù),就是你的這個(gè)回調(diào)函數(shù)名。這樣,系統(tǒng)在須要的時(shí)候,就會(huì)調(diào)用你寫的回調(diào)函數(shù),這樣你就可以在回調(diào)函數(shù)里完成你要做的事。
B.如何定義和實(shí)現(xiàn)一個(gè)類的成員函數(shù)為回調(diào)函數(shù)
要定義和實(shí)現(xiàn)一個(gè)類的成員函數(shù)為回調(diào)函數(shù)需要做三件事:
a.聲明;
b.定義;
c.設(shè)置觸發(fā)條件,就是在你的函數(shù)中把你的回調(diào)函數(shù)名作為一個(gè)參數(shù),以便系統(tǒng)調(diào)用
如:
一、聲明回調(diào)函數(shù)類型
typedefvoid(*FunPtr)(void);
二、定義回調(diào)函數(shù)
classA
{
public:
A();
staticvoidcallBackFun(void)//回調(diào)函數(shù),需要聲明為static
{
coutcallBackFun
}
virtual~A();
};
三、設(shè)置觸發(fā)條件
voidFuntype(FunPtrp)
{
p();
}
voidmain(void)
{
Funtype(A::callBackFun);
}
C.回調(diào)函數(shù)與API函數(shù)
回調(diào)和API特別接近,他們的共性都是跨層調(diào)用的函數(shù)。但區(qū)分是API是低層提供應(yīng)高層的調(diào)用,一般這個(gè)函數(shù)對(duì)高層都是已知的;而回調(diào)正好相反,他是高層提供應(yīng)底層的調(diào)用,對(duì)于低層他是未知的,需要由
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(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)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 溫州職業(yè)技術(shù)學(xué)院《創(chuàng)新創(chuàng)業(yè)能力訓(xùn)練》2023-2024學(xué)年第一學(xué)期期末試卷
- 二零二五版?zhèn)€人車位出租及車位租賃平臺(tái)合作合同3篇
- 二零二五年度貨物買賣合同涉及特定技術(shù)轉(zhuǎn)讓與售后服務(wù)2篇
- 2024版商場(chǎng)環(huán)保節(jié)能改造合同協(xié)議
- 二零二五版粉煤灰運(yùn)輸合同規(guī)范范本下載6篇
- 個(gè)性化房產(chǎn)代理合作協(xié)議樣本(2024)版B版
- 2024版房地產(chǎn)經(jīng)紀(jì)人與傭金合同3篇
- 二零二五年度適用于工程項(xiàng)目的自卸車租賃服務(wù)合同范本3篇
- 二零二五版基金代持及風(fēng)險(xiǎn)控制合作協(xié)議2篇
- 二零二五年餐飲店食品安全培訓(xùn)與認(rèn)證協(xié)議2篇
- 船形烏頭提取工藝優(yōu)化
- 財(cái)務(wù)總監(jiān)個(gè)人述職報(bào)告
- 居家養(yǎng)老護(hù)理人員培訓(xùn)方案
- 江蘇省無錫市2024年中考語文試卷【附答案】
- 管理者的九大財(cái)務(wù)思維
- 四年級(jí)上冊(cè)數(shù)學(xué)應(yīng)用題練習(xí)100題附答案
- 2024年度中國電建集團(tuán)北京勘測(cè)設(shè)計(jì)研究院限公司校園招聘高頻難、易錯(cuò)點(diǎn)500題模擬試題附帶答案詳解
- 有關(guān)企業(yè)會(huì)計(jì)人員個(gè)人工作總結(jié)
- 人教版高中數(shù)學(xué)必修二《第十章 概率》單元同步練習(xí)及答案
- 干部人事檔案專項(xiàng)審核工作情況報(bào)告(8篇)
- 智慧校園信息化建設(shè)項(xiàng)目組織人員安排方案
評(píng)論
0/150
提交評(píng)論