版權(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024工程招標(biāo)合同范本
- 2024年度云服務(wù)租賃合同
- 公司春節(jié)晚會(huì)活動(dòng)策劃3篇
- 2024年度智能家居安防監(jiān)控系統(tǒng)安裝與維護(hù)合同
- 2024年商業(yè)物業(yè)管理合同
- 2024雙方關(guān)于環(huán)保設(shè)備的買賣合同
- 2024年廢物分類與回收協(xié)議
- 2024年度CFG樁基工程項(xiàng)目管理合同
- 2024年度產(chǎn)品質(zhì)量保證與維修服務(wù)合同
- 2024年夫妻雙方關(guān)于房產(chǎn)買賣及產(chǎn)權(quán)分配協(xié)議
- 2024版人教版英語初一上單詞默寫單
- 化學(xué)實(shí)驗(yàn)室安全智慧樹知到期末考試答案2024年
- 經(jīng)典房地產(chǎn)營銷策劃培訓(xùn)(全)
- 工人入場安全教育課件
- 【川教版】《生命 生態(tài) 安全》二年級(jí)上冊(cè)第12課 少點(diǎn)兒馬虎 多點(diǎn)兒收獲 課件
- 人教版數(shù)學(xué)四年級(jí)上冊(cè)第五單元 《平行四邊形和梯形》 大單元作業(yè)設(shè)計(jì)
- 靜配中心差錯(cuò)預(yù)防
- 送教上門體育、健康教案教學(xué)內(nèi)容
- 高夫品牌市場分析報(bào)告
- 職業(yè)規(guī)劃書-數(shù)字化設(shè)計(jì)與制造技術(shù)
- 國家臨床重點(diǎn)專科建設(shè)項(xiàng)目申報(bào)書
評(píng)論
0/150
提交評(píng)論