當(dāng)前位置:首頁 > 嵌入式培訓(xùn) > 嵌入式招聘 > 嵌入式面試題 > 10道嵌入式工程師面試題(第一彈)
我們根據(jù)以往的學(xué)員的面試經(jīng)歷,為大家整理了一些面試經(jīng)常會遇到的題目,希望這些干貨對大家面試有所幫助。
一.已知一個數(shù)組table,用一個宏定義,求出數(shù)據(jù)的元素個數(shù)
答: #define NTBL (sizeof(tabl
二.一個32位的機(jī)器,該機(jī)器的指針是多少位?
答:指針是多少位只要看地址總線的位數(shù)就行了。80386以后的機(jī)子都是32的數(shù)據(jù)總線。所以指針的位數(shù)就是4個字節(jié)了。
三.關(guān)鍵字const有什么含義?
答:1)只讀。2)使用關(guān)鍵字const也許能產(chǎn)生更緊湊的代碼。3)使編譯器很自然地保護(hù)那些不希望被改變的參數(shù),防止其被無意的代碼修改。
四.TCP與UDP有啥區(qū)別?
答:TCP和UDP是OSI模型中的運輸層中的協(xié)議。TCP提供可靠的通信傳輸,而UDP則常被用于廣播和細(xì)節(jié)控制交給應(yīng)用的通信傳輸,兩者主要的不同體現(xiàn)在一下幾個方面:
1、TCP面向連接(如打電話要先撥號建立連接);UDP是無連接的,即發(fā)送數(shù)據(jù)之前不需要建立連接
2、TCP提供可靠的服務(wù)。它通過校驗和,丟包時的重傳控制,序號標(biāo)識,滑動窗口、確認(rèn)應(yīng)答,次序亂掉的分包進(jìn)行順序控制實現(xiàn)可靠傳輸。即通過TCP連接傳送的數(shù)據(jù),無差錯,不丟失,不重復(fù),且按序到達(dá); UDP盡最大努力交付,即不保證可靠交付。
3、UDP具有較好的實時性,工作效率比TCP高,適用于對高速傳輸和實時性有較高要求的通信或廣播通信場景。
4、每一條TCP連接只能是點到點的; UDP支持一對一,一對多,多對一和多對多的交互通信方式。
5、TCP對系統(tǒng)資源要求較多,UDP對系統(tǒng)資源要求較少。
UDP有時比TCP更有優(yōu)勢:
UDP以其簡單、傳輸快的優(yōu)勢,在越來越多場景下取代了TCP, 如實時游戲。
(1)網(wǎng)速的提升給UDP的穩(wěn)定性提供可靠網(wǎng)絡(luò)保障,丟包率很低,如果使用應(yīng)用層重傳,能夠確保傳輸?shù)目煽啃浴?/p>
(2)TCP為了實現(xiàn)網(wǎng)絡(luò)通信的可靠性,使用了復(fù)雜的擁塞控制算法,建立了繁瑣的握手過程,由于TCP在內(nèi)置的系統(tǒng)協(xié)議棧中,極難對其進(jìn)行改進(jìn)。
采用TCP,一旦發(fā)生丟包,TCP會將后續(xù)的包緩存起來,等前面的包重傳并接收到后再繼續(xù)發(fā)送,延時會越來越大。
基于UDP對實時性要求較為嚴(yán)格的情況下,采用自定義重傳機(jī)制,能夠把丟包產(chǎn)生的延遲降到最低,盡量減少網(wǎng)絡(luò)問題造成的影響。
五.請問以下代碼有什么問題:
int main() {
char a;
char *str=&a;
strcpy(str,"hello");
printf(str);
return 0;
}
答:沒有為str分配內(nèi)存空間,將會發(fā)生異常,問題出在將一個字符串復(fù)制進(jìn)一個字符變量指針?biāo)傅刂贰km然可以正確輸出結(jié)果,但因為越界進(jìn)行內(nèi)在讀寫而導(dǎo)致程序崩潰。
e)/sizeof(table[0]))
2.程序的局部變量存在于哪里,全局變量存在于哪里,動態(tài)申請數(shù)據(jù)存在于哪里。
答:程序的局部變量存在于棧區(qū);全局變量存在于靜態(tài)區(qū);動態(tài)申請數(shù)據(jù)存在于堆區(qū)。
六.寫一個"標(biāo)準(zhǔn)"宏MIN ,這個宏輸入兩個參數(shù)并返回較小的一個
答:#define MIN(A,B) ((A) <= (B) ? (A) : (B))
考點:
1) 標(biāo)識#define在宏中應(yīng)用的基本知識。這是很重要的。因為在 嵌入(inline)操作符 變?yōu)闃?biāo)準(zhǔn)C的一部分之前,宏是方便產(chǎn)生嵌入代碼的唯一方法,對于嵌入式系統(tǒng)來說,為了能達(dá)到要求的性能,嵌入代碼經(jīng)常是必須的方法。
2) 三重條件操作符的知識。這個操作符存在C語言中的原因是它使得編譯器能產(chǎn)生比if-then-else更優(yōu)的代碼,了解這個用法是很重要的。
3) 懂得在宏中小心地把參數(shù)用括號括起來。
七.引用與指針有什么區(qū)別?
答:
1) 引用必須被初始化,指針不必。
2) 引用初始化以后不能被改變,指針可以改變所指的對象。
3) 不存在指向空值的引用,但是存在指向空值的指針。
八.do……while和while有什么區(qū)別?
答:前一個循環(huán)一遍再判斷,后一個判斷以后再循環(huán)。
九.什么是預(yù)編譯,何時需要預(yù)編譯?
答:
1、總是使用不經(jīng)常改動的大型代碼體。
2、程序由多個模塊組成,所有模塊都使用一組標(biāo)準(zhǔn)的包含文件和相同的編譯選項。在這種情況下,可以將所有包含文件預(yù)編譯為一個預(yù)編譯頭。
預(yù)編譯指令指示了在程序正式編譯前就由編譯器進(jìn)行的操作,可以放在程序中的任何位置。
十.產(chǎn)生死鎖的原因是什么?
答:多個并發(fā)進(jìn)程因爭奪系統(tǒng)資源而產(chǎn)生相互等待的現(xiàn)象。即:一組進(jìn)程中的每個進(jìn)程都在等待某個事件發(fā)生,而只有這組進(jìn)程中的其他進(jìn)程才能觸發(fā)該事件,這就稱這組進(jìn)程發(fā)生了死鎖。
產(chǎn)生死鎖的本質(zhì)原因為:
1)、系統(tǒng)資源有限。
2)、進(jìn)程推進(jìn)順序不合理。
希望以上整理的面試題能對眾位求職者有所幫助。