freepeople性欧美熟妇, 色戒完整版无删减158分钟hd, 无码精品国产vα在线观看DVD, 丰满少妇伦精品无码专区在线观看,艾栗栗与纹身男宾馆3p50分钟,国产AV片在线观看,黑人与美女高潮,18岁女RAPPERDISSSUBS,国产手机在机看影片

正文內(nèi)容

第六章運(yùn)行時(shí)存儲(chǔ)空間的組織和管理-文庫吧資料

2024-08-14 13:21本頁面
  

【正文】 show。 show end。 var r: real。 begin write(r: 5: 3) end。 var r: real。 small。 writeln。 show。 show end。 var r: real。 begin write(r: 5: 3) end。 var r: real。 small。 writeln。 show。 show end。 var r: real。 begin write(r: 5: 3) end。 var r: real。 begin f := a。 procedure b (g: function (integer): integer)。 begin m:= 0。 function addm (n: integer): integer。 function a: function (integer): integer。 b(f) end. a ret b addm 非局部名字的訪問 program ret (input, output)。 begin writeln (g(2)) end。 return addm end。 begin return m+n end。 var m: integer。( 過程作為返回值 ) var f: function (integer): integer。 b(f) end {c}。 function f(n: integer)… begin f := m+n end {f}。 procedure c。 begin c end. f作為參數(shù)傳遞時(shí),它的起始地址連同它的訪問鏈一起傳遞 訪 問 鏈 訪 問 鏈 param c m b f, 非局部名字的訪問 program param(input, output)。 begin m := 0。 var m: integer。( 過程作為參數(shù) ) procedure b(function h(… begin writeln(h(2)) end 。 b(f) end {c}。 function f(n: integer)… begin f := m+n end {f}。 procedure c。 begin c end. 函數(shù) f作為參數(shù)傳遞時(shí),怎樣在 f被激活時(shí)建立它的訪問鏈 非局部名字的訪問 program param(input, output)。 begin m := 0。 function f(n: integer): integer。 procedure c。( 過程作為參數(shù) ) procedure b(function h(n: integer): integer)。j。 q = dangle ( )。 全局棧式存儲(chǔ)分配 棧上可變長數(shù)據(jù) 活動(dòng)記錄的長度在編譯時(shí)不能確定的情況 ? 例:局部數(shù)組的大小要等到過程激活時(shí)才能確定 備注: Java語言的實(shí)現(xiàn)是將它們分配在堆上 全局棧式存儲(chǔ)分配 訪問動(dòng)態(tài)分配的數(shù)組 控制鏈 數(shù)組 A的指針 數(shù)組 B的指針 top_sp base_sp . . . . . . . . . 棧 (1) 編譯時(shí),在活動(dòng)記錄中為這樣的數(shù)組分配存放數(shù)組指針的單元 全局棧式存儲(chǔ)分配 訪問動(dòng)態(tài)分配的數(shù)組 (2) 運(yùn)行時(shí),這些指針指向分配在棧頂?shù)臄?shù)組存儲(chǔ)空間 控制鏈 數(shù)組 A的指針 數(shù)組 B的指針 top_sp base_sp . . . . . . . . . 棧 數(shù)組 A 數(shù)組 B 全局棧式存儲(chǔ)分配 訪問動(dòng)態(tài)分配的數(shù)組 (3) 運(yùn)行時(shí),對(duì)數(shù)組 A和 B的訪問都要通過相應(yīng)指針來間接訪問 控制鏈 數(shù)組 A的指針 數(shù)組 B的指針 top_sp base_sp . . . . . . . . . 棧 數(shù)組 A 數(shù)組 B 全局棧式存儲(chǔ)分配 訪問動(dòng)態(tài)分配的數(shù)組 q的數(shù)組 q的活動(dòng)記錄 p的數(shù)組 p的活動(dòng)記錄 控制鏈 top_sp base_sp 數(shù)組 A的指針 數(shù)組 B的指針 數(shù)組 A 數(shù)組 B 控制鏈 . . . . . . . . . 棧 全局棧式存儲(chǔ)分配 懸空引用 懸空引用: 引用某個(gè)已被釋放的存儲(chǔ)單元 全局棧式存儲(chǔ)分配 懸空引用 懸空引用: 引用某個(gè)已被釋放的存儲(chǔ)單元 例: main中引用 p指向的對(duì)象 main( ) { | int ? dangle ( ) { int ?q。 B3 a0 b0 b1 a2, b3 重疊分配存儲(chǔ)單元 全局棧式存儲(chǔ)分配 本節(jié)介紹 ? 介紹程序運(yùn)行時(shí)所需的各個(gè)活動(dòng)記錄在存儲(chǔ)空間的分配策略 ? 描述過程的目標(biāo)代碼怎樣訪問綁定到局部名字的存儲(chǔ)單元 ? 介紹三種分配策略 – 靜態(tài)分配策略 – 棧式分配策略 – 堆式分配策略 全局棧式存儲(chǔ)分配 運(yùn)行時(shí)內(nèi)存的劃分 代 碼 靜 態(tài) 數(shù) 據(jù) 堆 棧 全局棧式存儲(chǔ)分配 靜態(tài)分配 ? 名字在程序被編譯時(shí)綁定到存儲(chǔ)單元 , 不需要運(yùn)行時(shí)的任何支持 ? 綁定的生存期是程序的整個(gè)運(yùn)行期間 全局棧式存儲(chǔ)分配 靜態(tài)分配給語言帶來限制 ? 遞歸過程不被允許 ? 數(shù)據(jù)對(duì)象的長度和它在內(nèi)存中位置的限制 ,必須是在編譯時(shí)可以知道的 ? 數(shù)據(jù)結(jié)構(gòu)不能動(dòng)態(tài)建立 全局棧式存儲(chǔ)分配 ? 例 C程序的外部變量 、 靜態(tài)局部變量以及程序中出現(xiàn)的常量都可以靜態(tài)分配 ? 聲明在函數(shù)外面 – 外部變量 靜態(tài)分配 – 靜態(tài)外部變量 靜態(tài)分配 ? 聲明在函數(shù)里面 – 靜態(tài)局部變量 也是靜態(tài)分配 – 自動(dòng)變量 不能靜態(tài)分配 全局棧式存儲(chǔ)分配 活動(dòng)樹和運(yùn)行棧 活動(dòng)樹 – 用樹來描繪控制進(jìn)入和離開活動(dòng)的方式 m q(1,9) r p(1,9) q(1,3) q(1,0) p(1,3) q(2,3) q(2,1) q(3,3) p(2,3) q(5,9) q(5,5) p(5,9) q(7,9) q(7,7) q(9,9) p(7,9) 全局棧式存儲(chǔ)分配 ? 活動(dòng)樹的特點(diǎn) – 每個(gè)結(jié)點(diǎn)代表某過程的一個(gè)活動(dòng) – 根結(jié)點(diǎn)代表主程序的活動(dòng) – 結(jié)點(diǎn) a是結(jié)點(diǎn) b的父結(jié)點(diǎn) , 當(dāng)且僅當(dāng)控制流從 a的活動(dòng)進(jìn)入 b的活動(dòng) – 結(jié)點(diǎn) a處于結(jié)點(diǎn) b的左邊 , 當(dāng)且僅當(dāng) a的生存期先于 b的生存期 m q(1,9) r p(1,9) q(1,3) . . . . q(5,9) . . . . 全局棧式存儲(chǔ)分配 ? 當(dāng)前活躍著的過程活動(dòng)可以保存在一個(gè)棧中 – 例 控制棧的內(nèi)容: m, q (1, 9), q (1, 3), q (2, 3) m q(1,9) r p(1,9) q(1,3) q(1,0) p(1,3) q(2,3) q(2,1) q(3,3) p(2,3) q(5,9) q(5,5) p(5,9) q(7,9) q(7,7) q(9,9) p(7,9) 全局棧式存儲(chǔ)分配 運(yùn)行棧: 把控制棧中的信息拓廣到包括過程活動(dòng)所需的所有局部信息 ( 即活動(dòng)記錄 ) 全局棧式存儲(chǔ)分配 運(yùn)行棧: 把控制棧中的信息拓廣到包括過程活動(dòng)所需的所有局部信息 ( 即活動(dòng)記錄 ) main 棧 main 函數(shù)調(diào)用關(guān)系樹 全局棧式存儲(chǔ)分配 運(yùn)行棧: 把控制棧中的信息拓廣到包括過程活動(dòng)所需的所有局部信息 ( 即活動(dòng)記錄 ) main r 函數(shù)調(diào)用關(guān)系樹 main int i r ( ) 棧 全局棧式存儲(chǔ)分配 運(yùn)行棧: 把控制棧中的信息拓廣到包括過程活動(dòng)所需的所有局部信息 ( 即活動(dòng)記錄 ) main q(1,9) r 函數(shù)調(diào)用關(guān)系樹 main int i q (1, 9) int m, n 棧 全局棧式存儲(chǔ)分配 運(yùn)行棧: 把控制棧中的信息拓廣到包括過程活動(dòng)所需的所有局部信息 ( 即活動(dòng)記錄 ) main q(1,9) r p(1,9) q(1,3) main int i q (1, 9) int m, n int i q (1, 3) int m, n 棧 函數(shù)調(diào)用關(guān)系樹 全局棧式存儲(chǔ)分配 運(yùn)行棧: 把控制棧中的信息拓廣到包括過程活動(dòng)所需的所有局部信息 ( 即活動(dòng)記錄 ) main q(1,9) r p(1,9) q(1,3) q(1,0) p(1,3) main int i q (1, 9) int m, n int i q (1, 3) int m, n int i q (1, 0) int m, n 棧 函數(shù)調(diào)用關(guān)系樹 全局棧式存儲(chǔ)分配 調(diào)用序列 ? 過程調(diào)用和過程返回都需要執(zhí)行一些代碼來管理活動(dòng)記錄棧 , 保存或恢復(fù)機(jī)器狀態(tài)等 ? 過程調(diào)用序列 過程調(diào)用時(shí)執(zhí)行的分配活動(dòng)記錄 , 把信息填入它的域中 , 使被調(diào)用過程可以開始執(zhí)行的代碼 ? 過程返回序列 被調(diào)用過程返回時(shí)執(zhí)行的恢復(fù)機(jī)器狀態(tài) , 釋放被調(diào)用過程活動(dòng)記錄 , 使調(diào)用過程能夠繼續(xù)執(zhí)行的代碼 ? 調(diào)用序列和返回序列 常常都分成兩部分 , 分處于調(diào)用過程和被調(diào)用過程中 全局棧式存儲(chǔ)分配 ? 即使是同一種語言 , 過程調(diào)用序列 、 返回序列和活動(dòng)記錄中各域的排放次序 , 也會(huì)因?qū)崿F(xiàn)而異 ? 設(shè)計(jì)這些序列和活動(dòng)記錄 的一些原則 – 以活動(dòng)記錄中間的某個(gè) 位置作為基地址 – 長度能較早確定的域放在 活動(dòng)記錄的中間 臨 時(shí) 數(shù) 據(jù) 參 數(shù) 局 部 數(shù) 據(jù) 機(jī) 器 狀 態(tài) 訪 問 鏈 控 制 鏈 返 回 值 全局棧式存儲(chǔ)分配 ? 即使是同一種語言 , 過程調(diào)用序列 、 返回序列和活動(dòng)記錄中各域的排放次序 , 也會(huì)因?qū)崿F(xiàn)而異 ? 設(shè)計(jì)這些序列和活動(dòng)記錄 的一些原則 – 一般把臨時(shí)數(shù)據(jù)域放在 局部數(shù)據(jù)域的后面 – 把參數(shù)域和可能有的返回 值域放在緊靠調(diào)用者活動(dòng) 記錄的地方 臨 時(shí) 數(shù) 據(jù) 參 數(shù) 局 部 數(shù) 據(jù) 機(jī) 器 狀 態(tài) 訪 問 鏈 控 制 鏈 返 回 值 全局棧式存儲(chǔ)分配 ? 即使是同一種語言 , 過程調(diào)用序列 、 返回序列和活動(dòng)記錄中各域的排放次序 , 也會(huì)因?qū)崿F(xiàn)而異 ? 設(shè)計(jì)這些序列和活動(dòng)記錄 的一些原則 – 用同樣的代碼來執(zhí)行各個(gè) 活動(dòng)的保存和恢復(fù) 臨 時(shí) 數(shù) 據(jù) 參 數(shù) 局 部 數(shù) 據(jù) 機(jī) 器 狀 態(tài) 訪 問 鏈 控 制 鏈 返 回 值 全局棧式存儲(chǔ)分配 過程 p調(diào)用過程 q的調(diào)用序列 返回值和參數(shù) top_sp base_sp 臨時(shí)數(shù)據(jù)局部數(shù)據(jù) 控制鏈 和保存的機(jī)器狀態(tài) ? ? ? 全局棧式存儲(chǔ)分配 過程 p調(diào)用過程 q的調(diào)用序列 (1) p計(jì)算實(shí)參,依次放入棧頂,并在棧頂留出放返回值的空間。 B1? B3 int a = 2。 B0 ? B2 int b = 0。 }/? end of B2 ?/ {/? begin of B3 ?/ int b = 3。 { /? begin of B1 ?/ int b = 1。 } /? end of B3 ?/ } /? end of B1 ?/ } /? end of B0 ?/ 局部存儲(chǔ)分配 main() / ? 例 ?/ { /? begin of B0 ?/ int a = 0。 { /? begin of B2 ?/ i
點(diǎn)擊復(fù)制文檔內(nèi)容
環(huán)評(píng)公示相關(guān)推薦
文庫吧 www.dybbs8.com
備案圖鄂ICP備17016276號(hào)-1