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

下載本文檔

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

文檔簡介

2023年華為嵌入式筆試題

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

inta=4;

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

a=?

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

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

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

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

char*p=str;

intn=10;

請(qǐng)計(jì)算

sizeof(str)=?(1)

sizeof(p)=?(2)

sizeof(n)=?(3)

voidFoo(charstr[100]){

請(qǐng)計(jì)算

sizeof(str)=?(4)

}

void*p=malloc(100);

請(qǐng)計(jì)算

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++編譯后在符號(hào)庫中的名字與C語言的不同,被externC修飾的變

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

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

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

答:實(shí)型

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);

}

請(qǐng)問運(yùn)行Test函數(shù)會(huì)有什么樣的結(jié)果?

答:輸出“hello”

(2).voidTest(void){

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

strcpy(str,“hello”);

free(str);

if(str!=NULL){

strcpy(str,“world”);

printf(str);

}

}

請(qǐng)問運(yùn)行Test函數(shù)會(huì)有什么樣的結(jié)果?

答:輸出“world”

(3).char*GetMemory(void){

charp[]=helloworld;

returnp;

}

voidTest(void){

char*str=NULL;

str=GetMemory();

printf(str);

}

請(qǐng)問運(yùn)行Test函數(shù)會(huì)有什么樣的結(jié)果?

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

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

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

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

(1)不調(diào)用C++/C的字符串庫函數(shù),請(qǐng)編寫函數(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)立動(dòng)態(tài)增長和減小的數(shù)據(jù)構(gòu)造

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

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

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

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

8.CSingleLock是干什么的。

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

9.NEWTEXTMETRIC是什么。

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

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

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

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

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

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

立的運(yùn)行局部,這樣的程序會(huì)利于理解和修改。

其他狀況都使用單線程。

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

答:見下一題

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

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

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

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

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

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

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

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

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

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

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

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

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

13.C++中什么數(shù)據(jù)安排在棧或堆中,New安排數(shù)據(jù)是在近堆還是遠(yuǎn)堆中?

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

堆:程序運(yùn)行時(shí)動(dòng)態(tài)申請(qǐng),new和malloc申請(qǐng)的內(nèi)存就在堆上

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

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

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

等候。

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

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

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

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

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

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

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

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

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

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

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

答:見16

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

答:Internet掌握?qǐng)?bào)文協(xié)議,處于網(wǎng)絡(luò)層(IP層)

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

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

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

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

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

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

等待客戶端連接。

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

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

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

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

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

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

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

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

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

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

2.運(yùn)行時(shí)動(dòng)態(tài)鏈接(run-timedynamiclinking),運(yùn)行時(shí)可以通過LoadLibrary或Loa

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

出口地址

溫馨提示

  • 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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論