計(jì)算機(jī)四級(jí)嵌入式系統(tǒng)開(kāi)發(fā)工程師模擬試題
在日復(fù)一日的學(xué)習(xí)、工作生活中,我們最不陌生的就是試題了,借助試題可以為主辦方提供考生某方面的知識(shí)或技能狀況的信息。大家知道什么樣的試題才是好試題嗎?以下是小編收集整理的計(jì)算機(jī)四級(jí)嵌入式系統(tǒng)開(kāi)發(fā)工程師模擬試題,歡迎大家借鑒與參考,希望對(duì)大家有所幫助。
計(jì)算機(jī)四級(jí)嵌入式系統(tǒng)開(kāi)發(fā)工程師模擬試題 1
一、編程開(kāi)發(fā)能力:
1、用預(yù)處理指令#define聲明一個(gè)常數(shù),用以表明一年中有多少秒(忽略閏年問(wèn)題);寫一個(gè)“標(biāo)準(zhǔn)”宏MIN函數(shù),這個(gè)宏輸入兩個(gè)參數(shù)并返回較小的一個(gè)。
2、用變量a給出下面的定義:
(1)一個(gè)整型數(shù)(An integer);
(2)一個(gè)指向整型數(shù)的指針(A pointer to an integer);
(3)一個(gè)指向指針的指針,它指向的指針是指向一個(gè)整型數(shù)(A pointer to a pointer to an integer);
(4)一個(gè)有10個(gè)整型數(shù)的數(shù)組(An array of 10 integers);
(5)一個(gè)有10個(gè)指針的數(shù)組,該指針是指向一個(gè)整型數(shù)的(A array of 10 pointers to integers);
(6)一個(gè)指向有10個(gè)整型數(shù)組的指針(A pointer to an array of 10 integers);
(7)一個(gè)指向函數(shù)的指針,該函數(shù)有一個(gè)整型參數(shù)并返回一個(gè)整型數(shù)(A pointer to a function that takes an integer as an argument returns an integer);
(8)一個(gè)有10個(gè)指針的數(shù)組,該指針指向一個(gè)函數(shù),該函數(shù)有一個(gè)整型參數(shù)并返回一個(gè)整型數(shù)(An array of 10 pointers to functions that take an integer argument and return an integer);
3、關(guān)鍵字volatile有什么含義?并舉出三個(gè)不同的例子。
4、嵌入式系統(tǒng)總是要用戶對(duì)變量或寄存器進(jìn)行位操作,給定一個(gè)整型變量a,寫兩段代碼,第一個(gè)設(shè)置a 的bit 3,第二個(gè)清除a 的bit 3,在以上操作中,要保持其他位不變。
5、嵌入式系統(tǒng)經(jīng)常具有要求程序員去訪問(wèn)某特定的內(nèi)存位置的特點(diǎn),在某工程中,要去設(shè)置一絕對(duì)地址為0x67a9的整型變量的值為0xaa66。編譯器是一個(gè)純粹的ANSI編譯器,寫代碼去完成這一任務(wù)。
6、中斷是嵌入式系統(tǒng)中的重要組成部分,這導(dǎo)致了很多編譯開(kāi)發(fā)商提供一種擴(kuò)展——讓標(biāo)準(zhǔn)C支持中斷,具有代表性的是,產(chǎn)生一個(gè)新的關(guān)鍵字:__interrupt,下面的代碼就使用了__interrupt去定義了一個(gè)中斷子程序(ISR),請(qǐng)?jiān)u論下這段代碼的__interrupt,
double compute_area(double radius) {
double area=PI*radius*radius; print f(" Area"=%f,area); return area; }
7、盡管不像非嵌入式計(jì)算機(jī)那樣常見(jiàn),嵌入式系統(tǒng)還是有從堆(heap)中動(dòng)態(tài)分配內(nèi)存的過(guò)程的,那么嵌入式系統(tǒng)中,動(dòng)態(tài)分派內(nèi)存可能發(fā)生的問(wèn)題是什么?
8、關(guān)鍵字static 的作用是什么?
9、#include 與#include "file.h"的區(qū)別? 10、請(qǐng)說(shuō)出const 與#define 相比,有何優(yōu)點(diǎn)?
二、嵌入式系統(tǒng)編程:
1、進(jìn)程與線程有什么區(qū)別?
2、操作系統(tǒng)有哪幾個(gè)特征?最主要的特征是什么?虛擬存儲(chǔ)器有哪幾個(gè)特征?
其最本質(zhì)的特征是什么?
3、庫(kù)函數(shù)的調(diào)用和系統(tǒng)調(diào)用的區(qū)別?
4、Linux進(jìn)程間通行方式有哪幾種以及各自的特點(diǎn)?
5、Linux中四層網(wǎng)絡(luò)模型?IP的'各種類型的范圍?
6、在Linux系統(tǒng)中,造成死鎖的原因有哪些?
7、Linux網(wǎng)絡(luò)編程中主要使用的API有哪些以及網(wǎng)絡(luò)服務(wù)器模型的種類? 8、簡(jiǎn)述對(duì)Linux的認(rèn)識(shí)(特點(diǎn),優(yōu)勢(shì))。
三、嵌入式平臺(tái)開(kāi)發(fā)
1、bootloader 是什么?bootloader的stage1和stage2分別做的工作有哪些? 2、Linux內(nèi)核版本命名的規(guī)則? 3、Linux設(shè)備文件有哪幾類?
4、Linux文件系統(tǒng)的種類有哪些以及使用特點(diǎn)? 5、嵌入式系統(tǒng)移植的主要工作步驟是什么?
四、編程能力實(shí)測(cè)
1、編寫一個(gè)C函數(shù),將“I am from shanghai”倒置為“shanghai from am I”即將句子中的單詞位置倒置,并不改變單詞內(nèi)部結(jié)構(gòu)。
2、請(qǐng)編寫一個(gè)C函數(shù),該函數(shù)可以實(shí)現(xiàn)將一個(gè)整數(shù)轉(zhuǎn)為任意進(jìn)制的字符串輸出。
計(jì)算機(jī)四級(jí)嵌入式系統(tǒng)開(kāi)發(fā)工程師模擬試題 2
1、下面有關(guān)servlet中init,service,destroy方法描述錯(cuò)誤的是?
A.init()方法是servlet生命的起點(diǎn)。一旦加載了某個(gè)servlet,服務(wù)器將立即調(diào)用它的init()方法
B.Service()方法處理客戶機(jī)發(fā)出的所有請(qǐng)求
C.destroy()方法標(biāo)志servlet生命周期的結(jié)束
D.servlet在多線程下使用了同步機(jī)制,因此,在并發(fā)編程下servlet是線程安全的
參考答案:D
2、下面有關(guān)java和c++的描述,錯(cuò)誤的是?
A.java是一次編寫多處運(yùn)行,c++是一次編寫多處編譯
B.c++和java支持多重承
C.Java不支持操作符重載,操作符重載被認(rèn)為是c++的突出特征
D.java沒(méi)有函數(shù)指針機(jī)制,c++支持函數(shù)指針
參考答案:B
3、()設(shè)計(jì)模式將抽象部分與它的實(shí)現(xiàn)部分相分離。
A.Singleton(單例)
B.Bridge(橋接)
C.Composite(組合)
D.Facade(外觀)
參考答案:B
4、哪些設(shè)計(jì)模式是降低資源使用率:
A.prototype
B.singleton
C.flyweight
D.abstract factory
參考答案:BC
5、運(yùn)行在多核處理器上的Linux環(huán)境中,若臨界區(qū)非常短,且不允許線程上下文切換的情況下,使用下列哪種機(jī)制滿足上述需求并且性能最好?
A.SpinLock
B.Mutex
C.Semaphore
D.Condition variable
參考答案:C
6、Unix系統(tǒng)中,哪些可以用于進(jìn)程間的通信?()
A.Socket
B.共享內(nèi)存
C.消息隊(duì)列
D.信號(hào)量
參考答案:ABCD
7、對(duì)一些資源以及狀態(tài)的操作保存,最好是保存在生命周期的哪個(gè)函數(shù)中進(jìn)行?
A.onPause()
B.onCreate()
C.onResume()
D.onStart()
參考答案:A
8、在android中使用Menu時(shí)可能需要重寫的方法有?
A.onCreateOptionsMenu()
B.onCreateMenu()
C.onOptionsItemSelected()
D.onItemSelected()
參考答案:AC
二、解答題
1、編寫一個(gè)函數(shù),作用是把一個(gè)char組成的字符串循環(huán)右移n個(gè)。比如原來(lái)是“abcdefghi”如果n=2,移位后應(yīng)該是“hiabcdefgh” 函數(shù)頭是這樣的:
//pStr是指向以結(jié)尾的'字符串的指針
//steps是要求移動(dòng)的n
void LoopMove ( char * pStr, int steps )
{
//請(qǐng)?zhí)畛?..
}
參考答案
正確解答1:
void LoopMove ( char *pStr, int steps )
{
int n = strlen( pStr ) - steps;
char tmp[MAX_LEN];
strcpy ( tmp, pStr + n );
strcpy ( tmp + steps, pStr);
*( tmp + strlen ( pStr ) ) = ;
strcpy( pStr, tmp );
}
正確解答2:
void LoopMove ( char *pStr, int steps )
{
int n = strlen( pStr ) - steps;
char tmp[MAX_LEN];
memcpy( tmp, pStr + n, steps );
memcpy(pStr + steps, pStr, n );
memcpy(pStr, tmp, steps );
}
【剖析】
這個(gè)試題主要考查面試者對(duì)標(biāo)準(zhǔn)庫(kù)函數(shù)的熟練程度,在需要的時(shí)候引用庫(kù)函數(shù)可以很大程度上簡(jiǎn)化程序編寫的工作量。
最頻繁被使用的庫(kù)函數(shù)包括:
(1) strcpy
(2) memcpy
(3) memset
2、軟件測(cè)試應(yīng)該劃分幾個(gè)階段?簡(jiǎn)述各個(gè)階段應(yīng)重點(diǎn)測(cè)試的點(diǎn)?各個(gè)階段的含義?
參考答案:
大體上來(lái)說(shuō)可分為單元測(cè)試,集成測(cè)試,系統(tǒng)測(cè)試,驗(yàn)收測(cè)試,每個(gè)階段又分為以下五個(gè)步驟: 測(cè)試計(jì)劃,測(cè)試設(shè)計(jì),用例設(shè)計(jì),執(zhí)行結(jié)果,測(cè)試報(bào)告
初始測(cè)試集中在每個(gè)模塊上,保證源代碼的正確性,該階段成為單元測(cè)試,主要用白盒測(cè)試方法。 接下來(lái)是模塊集成和集成以便組成完整的軟件包。集成測(cè)試集中在證實(shí)和程序構(gòu)成問(wèn)題上。主要采用黑盒測(cè)試方法,輔之以白盒測(cè)試方法。
軟件集成后,需要完成確認(rèn)和系統(tǒng)測(cè)試。確認(rèn)測(cè)試提供軟件滿足所有功能、性能需求的最后保證。確認(rèn)測(cè)試僅僅應(yīng)用黑盒測(cè)試方法。
計(jì)算機(jī)四級(jí)嵌入式系統(tǒng)開(kāi)發(fā)工程師模擬試題 3
1、一根金條長(zhǎng)31厘米,如果把它切成數(shù)段,使其中的一段或幾段能夠接成長(zhǎng)為1到31中任何整數(shù)的金條,請(qǐng)問(wèn)要切幾次?
A.4
B.5
C.6
D.7
參考答案:A
2、運(yùn)行在多核處理器上的Linux環(huán)境中,若臨界區(qū)非常短,且不允許線程上下文切換的情況下,使用下列哪種機(jī)制滿足上述需求并且性能最好?
A.SpinLock
B.Mutex
C.Semaphore
D.Condition variable
參考答案:A
3、以下程序輸出的結(jié)果是()
#include
int main(){
int x=10,y=10;
printf("%d %d",x--,--y);
}
A.10 10
B.9 9
C.9 10
D.10 9
參考答案:D
4、下面所述步驟中,不是創(chuàng)建進(jìn)程所必須的步驟是?
A.由調(diào)度程序?yàn)檫M(jìn)程分配CPU
B.建立一個(gè)進(jìn)程控制塊
C.為進(jìn)程分配內(nèi)存
D.將進(jìn)程控制塊鏈入就緒隊(duì)列
參考答案:A
5、下面描述中,表達(dá)正確的有()
A.公有繼承是基類中的public成員在派生類中仍是public的
B.公有繼承是基類中的private成員在派生類中仍是private的
C.公有繼承是基類中的protected成員在派生類中仍是protected的
D.私有繼承是基類中的public成員在派生類中仍是private的
參考答案:ACD
6、int listen(SOCKET s, int backlog);該函數(shù)中第二個(gè)參數(shù)的含義是?
A.是否打開(kāi)log信息
B.是否打開(kāi)后臺(tái)log信息
C.后臺(tái)等待連接隊(duì)列的最大限制值
D.后臺(tái)等待連接隊(duì)列的最小限制值
參考答案:C
7、Java程序中的類名稱必須與存放該類的文件名相同。
A.對(duì)
B.錯(cuò)
參考答案:B
8、造成軟件危機(jī)的主要原因是以下里的'哪幾個(gè)?
、儆脩羰褂貌划(dāng) ②硬件不可靠 ③對(duì)軟件的錯(cuò)誤認(rèn)識(shí) ④缺乏好的開(kāi)發(fā)方法和手段 ⑤軟件本身特點(diǎn) ⑥開(kāi)發(fā)效率低
A.(①②③)
B.(②③④)
C.(③⑤⑥)
D.(④⑤⑥)
參考答案:D
9、下面有個(gè)hibernate延遲加載,說(shuō)法錯(cuò)誤的是?
A.Hibernate2延遲加載實(shí)現(xiàn):a)實(shí)體對(duì)象 b)集合(Collection)
B.Hibernate3 提供了屬性的延遲加載功能
C.get支持延遲加載,load不支持延遲加
D.hibernate使用Java反射機(jī)制,而不是字節(jié)碼增強(qiáng)程序來(lái)實(shí)現(xiàn)透明性
參考答案:C
10、確定模塊的功能和模塊的接口是在軟件設(shè)計(jì)的那個(gè)階段完成的?
A.需求分析
B.概要設(shè)計(jì)
C.詳細(xì)設(shè)計(jì)
D.編碼
參考答案:B
【計(jì)算機(jī)四級(jí)嵌入式系統(tǒng)開(kāi)發(fā)工程師模擬試題】相關(guān)文章:
計(jì)算機(jī)四級(jí)嵌入式系統(tǒng)開(kāi)發(fā)工程師模擬試題10-12
2015計(jì)算機(jī)四級(jí)嵌入式系統(tǒng)開(kāi)發(fā)工程師模擬試題10-31
嵌入式系統(tǒng)開(kāi)發(fā)工程師模擬試題09-16
2024年計(jì)算機(jī)四級(jí)嵌入式系統(tǒng)開(kāi)發(fā)工程師模擬試題10-25
嵌入式系統(tǒng)開(kāi)發(fā)工程師模擬試題201610-07
2015嵌入式系統(tǒng)開(kāi)發(fā)工程師模擬試題10-08
最新嵌入式系統(tǒng)開(kāi)發(fā)工程師模擬試題10-23