2023年華為嵌入式筆試題_第1頁
2023年華為嵌入式筆試題_第2頁
2023年華為嵌入式筆試題_第3頁
2023年華為嵌入式筆試題_第4頁
2023年華為嵌入式筆試題_第5頁
已閱讀5頁,還剩8頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

2023年華為嵌入式筆試題

1.寫出推斷ABCD四個表達式的是否正確,若正確,寫出經(jīng)過表達式中a的值(3分)

inta=4;

(A)a+=(a++);(B)a+=(++a);(C)(a++)+=a;(D)(++a)+=(a++);

a=?

答:C錯誤,左側(cè)不是一個有效變量,不能賦值,可改為(++a)+=a;

改后答案依次為9,10,10,11

2.某32位系統(tǒng)下,C++程序,請計算sizeof的值(5分).

charstr[]=“http://./”

char*p=str;

intn=10;

請計算

sizeof(str)=?(1)

sizeof(p)=?(2)

sizeof(n)=?(3)

voidFoo(charstr[100]){

請計算

sizeof(str)=?(4)

}

void*p=malloc(100);

請計算

sizeof(p)=?(5)

答:(1)1725(2)4(3)4(4)4(5)4

3.答復(fù)下面的問題.(4分)

(1).頭文件中的ifndef/define/endif干什么用?預(yù)處理

答:防止頭文件被重復(fù)引用

(2).#include和#include“filename.h”有什么區(qū)分?

答:前者用來包含開發(fā)環(huán)境供應(yīng)的庫頭文件,后者用來包含自己編寫的頭文件。

(3).在C++程序中調(diào)用被C編譯器編譯后的函數(shù),為什么要加extern“C”聲明?

答:函數(shù)和變量被C++編譯后在符號庫中的名字與C語言的不同,被externC修飾的變

量和函數(shù)是根據(jù)C語言方式編譯和連接的。由于編譯后的名字不同,C++程序不能直接調(diào)

用C函數(shù)。C++供應(yīng)了一個C連接交換指定符號extern“C”來解決這個問題。

(4).switch()中不允許的數(shù)據(jù)類型是?

答:實型

4.答復(fù)下面的問題(6分)

(1).VoidGetMemory(char**p,intnum){

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

}

voidTest(void){

char*str=NULL;

GetMemory(str,100);

strcpy(str,hello);

printf(str);

}

請問運行Test函數(shù)會有什么樣的結(jié)果?

答:輸出“hello”

(2).voidTest(void){

char*str=(char*)malloc(100);

strcpy(str,“hello”);

free(str);

if(str!=NULL){

strcpy(str,“world”);

printf(str);

}

}

請問運行Test函數(shù)會有什么樣的結(jié)果?

答:輸出“world”

(3).char*GetMemory(void){

charp[]=helloworld;

returnp;

}

voidTest(void){

char*str=NULL;

str=GetMemory();

printf(str);

}

請問運行Test函數(shù)會有什么樣的結(jié)果?

答:無效的指針,輸出不確定

5.編寫strcat函數(shù)(6分)

已知strcat函數(shù)的原型是char*strcat(char*strDest,constchar*strSrc);

其中strDest是目的字符串,strSrc是源字符串。

(1)不調(diào)用C++/C的字符串庫函數(shù),請編寫函數(shù)strcat

答:

VC源碼:

char*__cdeclstrcat(char*dst,constchar*src)

{

char*cp=dst;

while(*cp)

cp++;/*findendofdst*/

while(*cp++=*src++);/*Copysrctoendofdst*/

return(dst);/*returndst*/

}

(2)strcat能把strSrc的內(nèi)容連接到strDest,為什么還要char*類型的返回值?

答:便利賦值給其他變量

6.MFC中CString是類型安全類么?

答:不是,其它數(shù)據(jù)類型轉(zhuǎn)換到CString可以使用CString的成員函數(shù)Format來轉(zhuǎn)換

7.C++中為什么用模板類。

答:(1)可用來創(chuàng)立動態(tài)增長和減小的數(shù)據(jù)構(gòu)造

(2)它是類型無關(guān)的,因此具有很高的可復(fù)用性。

(3)它在編譯時而不是運行時檢查數(shù)據(jù)類型,保證了類型安全

(4)它是平臺無關(guān)的,可移植性

(5)可用于根本數(shù)據(jù)類型

8.CSingleLock是干什么的。

答:同步多個線程對一個數(shù)據(jù)類的同時訪問

9.NEWTEXTMETRIC是什么。

答:物理字體構(gòu)造,用來設(shè)置字體的高寬大小

10.程序什么時候應(yīng)當(dāng)使用線程,什么時候單線程效率高。

答:1.耗時的操作使用線程,提高應(yīng)用程序響應(yīng)

2.并行操作時使用線程,如C/S架構(gòu)的效勞器端并發(fā)線程響應(yīng)用戶的懇求。

3.多CPU系統(tǒng)中,使用線程提高CPU利用率

4.改善程序構(gòu)造。一個既長又簡單的進程可以考慮分為多個線程,成為幾個獨立或半獨

立的運行局部,這樣的程序會利于理解和修改。

其他狀況都使用單線程。

11.Windows是內(nèi)核級線程么。

答:見下一題

12.Linux有內(nèi)核級線程么。

答:線程通常被定義為一個進程中代碼的不同執(zhí)行路線。從實現(xiàn)方式上劃分,線程有兩

種類型:“用戶級線程”和“內(nèi)核級線程”。用戶線程指不需要內(nèi)核支持而在用戶程序

中實現(xiàn)的線程,其不依靠于操作系統(tǒng)核心,應(yīng)用進程利用線程庫供應(yīng)創(chuàng)立、同步、調(diào)度

和治理線程的函數(shù)來掌握用戶線程。這種線程甚至在象DOS這樣的操作系統(tǒng)中也可實現(xiàn)

,但線程的調(diào)度需要用戶程序完成,這有些類似Windows3.x的協(xié)作式多任務(wù)。另外一

種則需要內(nèi)核的參加,由內(nèi)核完成線程的調(diào)度。其依靠于操作系統(tǒng)核心,由內(nèi)核的內(nèi)部

需求進展創(chuàng)立和撤銷,這兩種模型各有其好處和缺點。用戶線程不需要額外的內(nèi)核開支

,并且用戶態(tài)線程的實現(xiàn)方式可以被定制或修改以適應(yīng)特別應(yīng)用的要求,但是當(dāng)一個線

程因I/O而處于等待狀態(tài)時,整個進程就會被調(diào)度程序切換為等待狀態(tài),其他線程得不

到運行的時機;而內(nèi)核線程則沒有各個限制,有利于發(fā)揮多處理器的并發(fā)優(yōu)勢,但卻占

用了更多的系統(tǒng)開支。

WindowsNT和OS/2支持內(nèi)核線程。Linux支持內(nèi)核級的多線程

13.C++中什么數(shù)據(jù)安排在?;蚨阎校琋ew安排數(shù)據(jù)是在近堆還是遠堆中?

答:棧:存放局部變量,函數(shù)調(diào)用參數(shù),函數(shù)返回值,函數(shù)返回地址。由系統(tǒng)治理

堆:程序運行時動態(tài)申請,new和malloc申請的內(nèi)存就在堆上

14.使用線程是如何防止消失大的波峰。

答:意思是如何防止同時產(chǎn)生大量的線程,方法是使用線程池,線程池具有可以同時提

高調(diào)度效率和限制資源使用的好處,線程池中的線程到達最大數(shù)時,其他線程就會排隊

等候。

15函數(shù)模板與類模板有什么區(qū)分?

答:函數(shù)模板的實例化是由編譯程序在處理函數(shù)調(diào)用時自動完成的,而類模板的實例化

必需由程序員在程序中顯式地指定。

16一般數(shù)據(jù)庫若消失日志滿了,會消失什么狀況,是否還能使用?

答:只能執(zhí)行查詢等讀操作,不能執(zhí)行更改,備份等寫操作,緣由是任何寫操作都要記

錄日志。也就是說根本上處于不能使用的.狀態(tài)。

17SQLServer是否支持行級鎖,有什么好處?

答:支持,設(shè)立封鎖機制主要是為了對并發(fā)操作進展掌握,對干擾進展封鎖,保證數(shù)據(jù)

的全都性和精確性,行級封鎖確保在用戶取得被更新的行到該行進展更新這段時間內(nèi)不

被其它用戶所修改。因而行級鎖即可保證數(shù)據(jù)的全都性又能提高數(shù)據(jù)操作的迸發(fā)性。

18假如數(shù)據(jù)庫滿了會消失什么狀況,是否還能使用?

答:見16

19關(guān)于內(nèi)存對齊的問題以及sizof()的輸出

答:編譯器自動對齊的緣由:為了提高程序的性能,數(shù)據(jù)構(gòu)造(尤其是棧)應(yīng)當(dāng)盡可能

地在自然邊界上對齊。緣由在于,為了訪問未對齊的內(nèi)存,處理器需要作兩次內(nèi)存訪問

;然而,對齊的內(nèi)存訪問僅需要一次訪問。

20inti=10,j=10,k=3;k*=i+j;k最終的值是?

答:60,此題考察優(yōu)先級,實際寫成:k*=(i+j);,賦值運算符優(yōu)先級最低

21.對數(shù)據(jù)庫的一張表進展操作,同時要對另一張表進展操作,如何實現(xiàn)?

答:將操作多個表的操作放入到事務(wù)中進展處理

22.TCP/IP建立連接的過程?(3-wayshake)

答:在TCP/IP協(xié)議中,TCP協(xié)議供應(yīng)牢靠的連接效勞,采納三次握手建立一個連接。

第一次握手:建立連接時,客戶端發(fā)送syn包(syn=j)到效勞器,并進入SYN_SEND狀

態(tài),等待效勞器確認;

其次次握手:效勞器收到syn包,必需確認客戶的SYN(ack=j+1),同時自己也發(fā)送一個

SYN包(syn=k),即SYN+ACK包,此時效勞器進入SYN_RECV狀態(tài);

第三次握手:客戶端收到效勞器的SYN+ACK包,向效勞器發(fā)送確認包ACK(ack=k+1)

,此包發(fā)送完畢,客戶端和效勞器進入ESTABLISHED狀態(tài),完成三次握手。

23.ICMP是什么協(xié)議,處于哪一層?

答:Internet掌握報文協(xié)議,處于網(wǎng)絡(luò)層(IP層)

24.觸發(fā)器怎么工作的?

答:觸發(fā)器主要是通過大事進展觸發(fā)而被執(zhí)行的,當(dāng)對某一表進展諸如UPDATE、INSERT

、DELETE這些操作時,數(shù)據(jù)庫就會自動執(zhí)行觸發(fā)器所定義的SQL語句,從而確保對數(shù)

據(jù)的處理必需符合由這些SQL語句所定義的規(guī)章。

25.winsock建立連接的主要實現(xiàn)步驟?

答:效勞器端:socker()建立套接字,綁定(bind)并監(jiān)聽(listen),用accept()

等待客戶端連接。

客戶端:socker()建立套接字,連接(connect)效勞器,連接上后使用send()和recv(

),在套接字上寫讀數(shù)據(jù),直至數(shù)據(jù)交換完畢,closesocket()關(guān)閉套接字。

效勞器端:accept()發(fā)覺有客戶端連接,建立一個新的套接字,自身重新開頭等待連

接。該新產(chǎn)生的套接字使用send()和recv()寫讀數(shù)據(jù),直至數(shù)據(jù)交換完畢,closesock

et()關(guān)閉套接字。

26.動態(tài)連接庫的兩種方式?

答:調(diào)用一個DLL中的函數(shù)有兩種方法:

1.載入時動態(tài)鏈接(load-timedynamiclinking),模塊特別明確調(diào)用某個導(dǎo)出函數(shù)

,使得他們就像本地函數(shù)一樣。這需要鏈接時鏈接那些函數(shù)所在DLL的導(dǎo)入庫,導(dǎo)入庫向

系統(tǒng)供應(yīng)了載入DLL時所需的信息及DLL函數(shù)定位。

2.運行時動態(tài)鏈接(run-timedynamiclinking),運行時可以通過LoadLibrary或Loa

dLibraryEx函數(shù)載入DLL。DLL載入后,模塊可以通過調(diào)用GetProcAddress獵取DLL函數(shù)的

出口地址

溫馨提示

  • 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論