經(jīng)典c++面試題四_第1頁
經(jīng)典c++面試題四_第2頁
經(jīng)典c++面試題四_第3頁
經(jīng)典c++面試題四_第4頁
經(jīng)典c++面試題四_第5頁
已閱讀5頁,還剩3頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

經(jīng)典c++面試題四

六)1)什么是預編譯,何時需要預編譯:總是使用不常常改動的大型代碼體。

程序由多個模塊組成,全部模塊都使用一組標準的包含文件和相同的編譯選項。在這種狀況下,可以將全部包含文件預編譯為一個預編譯頭。

2)char*constp;

charconst*p

constchar*p

上述三個有什么區(qū)分?

char*constp;//常量指針,p的值不行以修改

charconst*p;//指向常量的指針,指向的常量值不行以改

constchar*p;//和charconst*p

3)charstr1=“abc”;

charstr2=“abc”;

constcharstr3=“abc”;

constcharstr4=“abc”;

constchar*str5=“abc”;

constchar*str6=“abc”;

char*str7=“abc”;

char*str8=“abc”;

cout(Y)?(Y):(X))//結(jié)尾沒有;

10)嵌入式系統(tǒng)中常常要用到無限循環(huán),你怎么用C編寫死循環(huán)。

while(1){}或者for(;;)

軟件開發(fā)網(wǎng).

11)關鍵字static的作用是什么?

定義靜態(tài)變量

12)關鍵字const有什么含意?

表示常量不行以修改的變量。

13)關鍵字volatile有什么含意?并舉出三個不同的例子?

提示編譯器對象的值可能在編譯器未監(jiān)測到的狀況下轉(zhuǎn)變。

14)int(*s)(int)表示的是什么?

int(*s)(int)函數(shù)指針數(shù)組,每個指針指向一個intfunc(intparam)的函數(shù)。

15)有以下表達式:

inta=248;b=4;

intconstc=21;

constint*d=

int*conste=

intconst*fconst=

請問下列表達式哪些會被編譯器禁止?為什么?

*c=32;d=*d=43;e=34;e=f=0x321f;

*c這是個什么東東,禁止

*d說了是const,禁止

e=禁止

16)交換兩個變量的值,不使用第三個變量。即a=3,b=5,交換之后a=5,b=3;

有兩種解法,一種用算術算法,一種用^(異或)

a=a+b;

b=a–b;

a=a–b;

or

a=a^b;//只能對int,char..

b=a^b;

a=a^b;

or

a^=b^=a;

17)c和c++中的struct有什么不同?

c和c++中struct的主要區(qū)分是c中的struct不行以含有成員函數(shù),而c++中的struct可以。c++中struct和class的主要區(qū)分在于默認的存取權限不同,struct默認為public,而class默認為private。

18)#include

#include

voidgetmemory(char*p)

{

p=(char*)malloc(100);

strcpy(p,”helloworld”);

}

intmain()

{

char*str=NULL;

getmemory(str);

printf(“%s/n”,str);

free(str);

return0;

}

程序崩潰,getmemory中的malloc不能返回動態(tài)內(nèi)存,free()對str操作很危急

19)charszstr;

strcpy(szstr,”0123456789″);

產(chǎn)生什么結(jié)果?為什么?

長度不一樣,會造成非法的OS

20)列舉幾種進程的同步機制,并比較其優(yōu)缺點。

原子操作、信號量機制、自旋鎖、管程,會合,分布式系統(tǒng)

21)進程之間通信的途徑

1.管道2.信號3.消息隊列4.共享內(nèi)存

22)進程死鎖的緣由

(1)競爭資源

(2)進程推動挨次不當

23)死鎖的4個必要條件

互斥、部分安排、不行剝奪、循環(huán)

24)死鎖的處理

鴕鳥策略、預防策略、避開策略、檢測與解除死鎖

25)操作系統(tǒng)中進程調(diào)度策略有哪幾種?

FCFS(先來先服務),優(yōu)先級,時間片輪轉(zhuǎn),多級反饋

26)類的靜態(tài)成員和非靜態(tài)成員有何區(qū)分?

類的靜態(tài)成員每個類只有一個,非靜態(tài)成員每個對象一個

27)純虛函數(shù)如何定義?使用時應留意什么?

virtualvoidf()=0;

是接口,子類必需要實現(xiàn)

28)數(shù)組和鏈表的區(qū)分

數(shù)組:數(shù)據(jù)挨次存儲,固定大小

連表:數(shù)據(jù)可以隨機存儲,大小可動態(tài)轉(zhuǎn)變

29)ISO的七層模型是什么?tcp/udp是屬于哪一層?tcp/udp有何優(yōu)缺點?

應用層

表示層

會話層

運輸層

網(wǎng)絡層

物理鏈路層

物理層

tcp/udp屬于運輸層

TCP服務供應了數(shù)據(jù)流傳輸、牢靠性、有效流掌握、全雙工操作和多路復用技術等。

與TCP不同,UDP并不供應對IP協(xié)議的牢靠機制、流掌握以及錯誤恢復功能等。由于UDP比較簡潔,UDP頭包含很少的字節(jié),比TCP負載消耗少。

tcp:供應穩(wěn)定的傳輸服務,有流量掌握,缺點是包頭大,冗余性不好

udp:不供應穩(wěn)定的服務,包頭小,開銷小

30)(void*)ptr和(*(void**))ptr的結(jié)果是否相同?

其中ptr為同一個指針(void*)ptr和(*(void**))ptr值是相同的

32)intmain()

{

intx=3;

printf(“%d”,x);

return1;

}

問函數(shù)既然不會被其它函數(shù)調(diào)用,為什么要返回1?

mian中,c標準認為0表示勝利,非0表示錯誤。詳細的值是某中詳細出錯信息

33)要對肯定地址0×100000賦值,我們可以用(unsignedint*)0×100000=1234;那么要是想讓程序跳轉(zhuǎn)到肯定地址是0×100000去執(zhí)行,應當怎么做?

*((void(*)())0×100000)();

首先要將0×100000強制轉(zhuǎn)換成函數(shù)指針,即:

(void(*)())0×100000

然后再調(diào)用它:

*((void(*)())0×100000)();

用typedef可以看得更直觀些:

typedefvoid(*)()voidFuncPtr;

*((voidFuncPtr)0×100000)();

34)已知一個數(shù)組table,用一個宏定義,求出數(shù)據(jù)的元素個數(shù)

#defineNTBL

#defineNTBL(sizeof(table)/sizeof(table))

35)線程與進程的區(qū)分和聯(lián)系?線程是否具有相同的堆棧?dll是否有獨立的堆棧?

進程是死的,只是一些資源的集合,真正的程序執(zhí)行都是線程來完成的,程序啟動的時候操作系統(tǒng)就幫你創(chuàng)建了一個主線程。

每個線程有自己的堆棧。DLL中有沒有獨立的堆棧?

這個問題不好回答,或者說這個問題本身是否有問題。由于DLL中的代碼是被某些線程所執(zhí)行,只有線程擁有堆棧,假如DLL中的代碼是EXE中的線程所調(diào)用,那么這個時候是不是說這個DLL沒有自己獨立的堆棧?假如DLL中的代碼是由DLL自己創(chuàng)建的線程所執(zhí)行,那么是不是說DLL有獨立的堆棧?

以上講的是堆棧,假如對于堆來說,每個DLL有自己的堆,所以假如是從DLL中動態(tài)安排的內(nèi)存,最好是從DLL中刪除,假如你從DLL中安排內(nèi)存,然后在EXE中,或者另外一個DLL中刪除,很有可能導致程序崩潰。

36)unsignedshortA=10;

printf(“~A=%u\n”,~A);

charc=128;

printf(“c=%d\n”,c);

輸出多少?并分析過程

第一題,~A=0xfffffff5,int值為-11,但輸出的是uint。所以輸出4294967285

其次題,c=0×10,輸出的是int,最高位為1,是負數(shù),所以它的值就是0×00的補碼就是128,所以輸出-128。

這兩道題都是在考察二進制向int或uint轉(zhuǎn)換時的最高位處理。

37)分析下面的程序:

voidGetMemory(char**p,intnum)

{

*p=(char*)malloc(num);

}

intmain()

{

char*str=NULL;

GetMemory(

strcpy(str,”hello”);

free(str);

if(str!=NULL)

{

strcpy(str,”world”);

}

printf(“\nstris%s”,str);軟件開發(fā)網(wǎng).mscto.

getchar();

}

問輸出結(jié)果是什么?

輸出strisworld。

free只是釋放的str指向的內(nèi)存空間,它本身的值還是存在的.所以free之后,有一個好的習慣就是將str=NULL.

此時str指向空間的內(nèi)存已被回收,假如輸出語句之前還存在安排空間的操作的話,這段存儲空間是可能被重新安排給其他變量的,

盡管這段程序的確是存在大大的問題(上面各位已經(jīng)說得很清晰了),但是通常會打印出world來。

這是由于,進程中的內(nèi)存管理一般不是由操作系統(tǒng)完成的,而是由庫函數(shù)自己完成的。

當你malloc一塊內(nèi)存的時候,管理庫向操作系統(tǒng)申請一塊空間(可能會比你申請的大一些),然后在這塊空間中記錄一些管理信息(一般是在你申請的內(nèi)存前面一點),并將可用內(nèi)存的地址返回。但是釋放內(nèi)存的時候,管理庫通常都不會將內(nèi)存還給操作系統(tǒng),因此你是可以連續(xù)訪問這塊地址的。

chara,strlen(a)為什么等于15?運行的結(jié)果

38)#include“stdio.h”

#include“string.h”

voidmain()

{

charaa;

printf(“%d”,strlen(aa));

}

sizeof()和初不初始化,沒有關系;

strlen()和初始化有關。

39)char(*str);

char*str;

40)longa=0×801010;

a+5=?

0×801010用二進制表示為:“100000000001000000010000”,十進制的值為8392720,再加上5就是8392725羅

41)給定結(jié)構

structA

{

chart:4;

chark:4;

unsignedshorti:8;

unsignedlongm;

};

問sizeof(A)=?

給定結(jié)構

structA

{

chart:4;4位

chark:4;4位

unsignedshorti:8;8位

unsignedlongm;//偏移2字節(jié)保證4字節(jié)對齊

};//共8字節(jié)

42)下面的函數(shù)實現(xiàn)在一個數(shù)上加一個數(shù),有什么錯誤?請改正。

intadd_n(intn)

{

staticinti=100;

i+=n;

returni;

}

當你其次次調(diào)用時得不到正確的結(jié)果,莫非你寫個函數(shù)就是為了調(diào)用一次?問題就出在static上?

43)分析一下

#include

#include

#include

#include

#include

#include

typedefstructAA

{

intb1:5;

intb2:2;

}AA;

voidmain()

{

AAaa;

charcc;

strcpy(cc,”0123456789abcdefghijklmnopqrstuvwxyz”);

memcpy(

cout0

}

45)分析:

structbit

{

inta:3;

intb:2;

intc:3;

};

intmain()

{

bits;

char*c=(char

溫馨提示

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

評論

0/150

提交評論