亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

華為認(rèn)證

華為面試題:怎樣判斷棧的增長(zhǎng)方向

時(shí)間:2024-08-30 07:28:53 華為認(rèn)證 我要投稿
  • 相關(guān)推薦

華為面試題:怎樣判斷棧的增長(zhǎng)方向

  在華為面試中有這么一道考試,請(qǐng)給出棧增長(zhǎng)方向的判斷方法。下面一起來(lái)看看這道題的參考答案,僅供大家參考!

華為面試題:怎樣判斷棧的增長(zhǎng)方向

  該題目屬于考查計(jì)算機(jī)組成原理中棧結(jié)構(gòu)知識(shí)的題目。其參考答案如下:

  可以編寫一個(gè)帶有過程(函數(shù))調(diào)用的C程序,然后按照以下方法進(jìn)行判斷(采用類似思想,還可以寫出許多答案)。

  方法一:通過比較被調(diào)用過程中的入口參數(shù)所在地址和局部變量所在地址之間的大小來(lái)判斷。若入口參數(shù)所在地址大于局部變量所在地址,則棧是向低地址增長(zhǎng)的。

  方法二:直接閱讀匯編指令來(lái)判斷。例如,在IA-32中,如果在一個(gè)過程的開始階段(準(zhǔn)備段)出現(xiàn)類似“sub $0x10,%esp”指令,說(shuō)明棧頂指針(%esp)是變小的,因此棧是向低地址增長(zhǎng)的。

  方法三:顯示棧頂指針寄存器的內(nèi)容。在某個(gè)過程的開始階段和結(jié)束階段分別顯示棧頂指針寄存器的內(nèi)容,比較它們的大小。若開始處的值比結(jié)束處的大,則說(shuō)明棧是向低地址增長(zhǎng)的。

  后面兩種方法,需要對(duì)程序的機(jī)器級(jí)代碼(匯編指令)進(jìn)行調(diào)試,例如,利用Linux系統(tǒng)中的程序調(diào)試工具軟件GDB進(jìn)行調(diào)試。

  該題是開放題目,答案應(yīng)該沒有唯一性。通過這個(gè)題目的回答可以考查出學(xué)生對(duì)計(jì)算機(jī)系統(tǒng)中棧結(jié)構(gòu)的掌握情況。

  棧是存儲(chǔ)空間中的一個(gè)區(qū)域,分用戶棧和內(nèi)核棧兩種類型。用戶棧主要用來(lái)存放用戶進(jìn)程每次過程(函數(shù))調(diào)用時(shí),在被調(diào)用過程中使用的局部信息,每次過程調(diào)用都在棧中生長(zhǎng)出一個(gè)新的棧幀,因此,棧幀是通過執(zhí)行相應(yīng)的指令動(dòng)態(tài)生長(zhǎng)出來(lái)的;內(nèi)核棧是操作系統(tǒng)內(nèi)核中的動(dòng)態(tài)存儲(chǔ)區(qū)域,用于保存操作系統(tǒng)內(nèi)核和硬件所需要的動(dòng)態(tài)信息。

  在采用虛擬存儲(chǔ)管理機(jī)制的系統(tǒng)中,內(nèi)核棧和用戶棧都是虛擬地址空間中的一個(gè)存儲(chǔ)區(qū)。每個(gè)源程序經(jīng)編譯、匯編、鏈接等處理生成可執(zhí)行的二進(jìn)制機(jī)器目標(biāo)代碼時(shí),每個(gè)程序的目標(biāo)代碼都被映射到同樣的虛擬地址空間,所有用戶進(jìn)程的虛擬地址空間是一致的。例如,圖1給出了在IA32/Linux操作系統(tǒng)下hello程序的一個(gè)進(jìn)程對(duì)應(yīng)的虛擬地址空間映像。它分為兩大部分:內(nèi)核區(qū)(kernelarea)和用戶區(qū)(userarea)。

  從圖1可以看出,內(nèi)核區(qū)在0xC0000000以上的高端地址上,用來(lái)存放操作系統(tǒng)內(nèi)核代碼和數(shù)據(jù)以及與每個(gè)進(jìn)程相關(guān)的數(shù)據(jù)結(jié)構(gòu)(如進(jìn)程標(biāo)識(shí)信息、進(jìn)程現(xiàn)場(chǎng)信息、頁(yè)表等進(jìn)程控制信息以及內(nèi)核棧等),其中內(nèi)核代碼和數(shù)據(jù)區(qū)在每個(gè)進(jìn)程的地址空間中都相同。用戶程序沒有權(quán)限訪問內(nèi)核區(qū)。

  用戶區(qū)用來(lái)存放用戶進(jìn)程的代碼和數(shù)據(jù),它被分為以下幾個(gè)區(qū)域。

  (1) 用戶棧。用來(lái)存放程序運(yùn)行時(shí)過程調(diào)用的參數(shù)、返回值、返回地址、過程局部變量等,隨著程序的執(zhí)行,該區(qū)會(huì)不斷動(dòng)態(tài)地從高地址向低地址增長(zhǎng)或向反方向減退。

  (2) 共享庫(kù)。用來(lái)存放公共的共享函數(shù)庫(kù)代碼,如hello中的printf( )函數(shù)等。

  (3) 堆。用于動(dòng)態(tài)申請(qǐng)存儲(chǔ)區(qū),例如,C語(yǔ)言中用malloc()函數(shù)分配的存儲(chǔ)區(qū),或C++中用new操作符分配的存儲(chǔ)區(qū)。申請(qǐng)一塊內(nèi)存時(shí),動(dòng)態(tài)地從低地址向高地址增長(zhǎng),用free( )函數(shù)或delete操作符釋放一塊內(nèi)存時(shí),動(dòng)態(tài)地從高地址向低地址減退。

  (4) 可讀寫數(shù)據(jù)區(qū)。存放用戶進(jìn)程中的靜態(tài)全局變量,堆區(qū)從該區(qū)域的結(jié)尾處開始向高地址增長(zhǎng)。

  (5) 只讀數(shù)據(jù)和代碼區(qū)。存放用戶進(jìn)程中的代碼和只讀數(shù)據(jù),如hello進(jìn)程中的程序代碼和字符串“hello,world\n”。

  每個(gè)區(qū)域都有相應(yīng)的起始位置,堆區(qū)和棧區(qū)相向生長(zhǎng),棧區(qū)從內(nèi)核起始位置0xC0000000開始向低地址增長(zhǎng),堆棧中的共享庫(kù)代碼區(qū)從0x40000000開始向高地址增長(zhǎng)。代碼和只讀數(shù)據(jù)區(qū)從0x08048000開始向高地址增長(zhǎng)。

  對(duì)于棧的訪問操作,有些指令集系統(tǒng)結(jié)構(gòu)提供了專門的入棧和出棧指令,例如Intel架構(gòu)中的push指令和pop指令分別用于入棧和出棧操作;有些架構(gòu)則不提供專門的入棧和出棧指令,而是通過訪存指令和加/減指令來(lái)實(shí)現(xiàn)入棧和出棧操作,例如,MIPS架構(gòu)中用sw指令和add或sub指令實(shí)現(xiàn)入棧操作,用lw指令和add或sub指令實(shí)現(xiàn)出棧操作。

  對(duì)于像Intel這樣提供專門入棧和出棧指令的情況,棧的增長(zhǎng)方向可以根據(jù)入棧、出棧指令的功能來(lái)確定,例如,IA-31架構(gòu)中的push指令自動(dòng)將棧頂指針減4,而pop指令則自動(dòng)將棧頂指針加4。因而,?偸菑母叩刂废虻偷刂吩鲩L(zhǎng)。

  對(duì)于像MIPS架構(gòu)這種沒有專門入棧和出棧指令的情況,棧的增長(zhǎng)方向就不一定,可能是高地址向低地址增長(zhǎng),或是相反。

  因?yàn)闂J峭ㄟ^執(zhí)行指令動(dòng)態(tài)增長(zhǎng)的,所以,最直接的判斷辦法就是在機(jī)器級(jí)代碼層面(通常是匯編指令)來(lái)閱讀或調(diào)試程序。

  當(dāng)一個(gè)過程P調(diào)用一個(gè)被調(diào)用過程Q,則P中傳遞給Q的參數(shù)會(huì)先入棧,然后執(zhí)行調(diào)用指令(如IA-32中的call指令),跳轉(zhuǎn)到Q執(zhí)行,在被調(diào)用過程Q中,再將Q的局部變量入棧,因此,通過比較Q過程的入口參數(shù)所在地址和局部變量所在地址之間的大小,可以判斷出棧的增長(zhǎng)方向。


相關(guān)文章推薦:

1.2016年華為筆試面試題及答案

2.華為c語(yǔ)言筆試面試題題庫(kù)

3.2016年華為筆試題及及答案

4.華為面試題:怎樣判斷棧的增長(zhǎng)方向

5.華為測(cè)試面試題匯總

6.2016年華為機(jī)試練習(xí)題及答案

7.2016年華為嵌入式筆試題

8.2016年華為認(rèn)證認(rèn)證試題(筆試)

9.2016年華為認(rèn)證C/C++筆試題目

10.2016年華為上機(jī)考試題

【華為面試題:怎樣判斷棧的增長(zhǎng)方向】相關(guān)文章:

華為Java面試題精選10-25

怎樣打方向07-10

華為c語(yǔ)言筆試面試題題庫(kù)08-16

2017華為筆試面試題庫(kù)09-12

怎樣判斷藥物副作用10-21

怎樣判斷主板電池沒電08-14

2016年華為筆試面試題及答案10-17

怎樣通過寶寶臉色判斷健康指數(shù)08-08

2016年華為網(wǎng)絡(luò)工程師面試題06-23

教你判斷硬盤是哪里出現(xiàn)了問題怎樣做10-24