
運行時存儲空間組織與管理是一個復雜而十分重要的問題,首先要了解一個過程(procedure)靜態源程序和它的目標程序在運行時的活動之間的關系。一個過程的活動指的是該過程的一次執行。為了管理過程在一次執行中所需要的信息.使用一個連續的存儲塊,我們把這樣的一個連續存儲塊稱為活動記錄。活動記錄中記錄臨時單元、內情向量、局部變量、形式單元、靜態鏈、動態鏈和返回地址。
存儲分田策略有三種:靜態分配、棧式動態分配和堆式動態分配。棧(stack)是一個特定的存儲區,它的一端是固定的,另端是浮動的.對這個存儲區.所有的信息存入也稱為堆陣式堆棧。棧的概念在編譯技術和其他軟件技術中被廣泛應用。堆(heap)是一個特定的存儲區.其分配使用方法是先把它成若干個長度可變的子存儲區,有些用干存入數據.有些供自由使用.當創建一片數據時.便需從自由公用區中選出一個足夠大自由區,把該數據存人。當該數據不再箭用時,便釋放相應的存區.這佯的存儲分配方式稱為堆式分配。堆式分配適用干理序運中長度可變的數據.如USP語育中的表等.
代瑪生成時,帝首先考慮奸相應干每個鐐程序或中間捏序的句的目標程序結構,然后一對多地轉換過去。其中還可能有些地事先不知道,可先待定,記下位置,拉上蛙,以后知淚了再回綴。為7生成更有效的目標代瑪.還有一個要重點考慮的問題是女何更有效地利用寄存器。另外.地址計算、數組引用等也都有不同,就不在此逐一敘述。