- 1、本文档共16页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
RunTimeStorageOrganization
CSE 5317/4305 L7: Run-Time Storage Organization * Run-Time Storage Organization Leonidas Fegaras Memory Layout Memory layout of an executable program: Run-Time Stack At run-time, function calls behave in a stack-like manner when you call, you push the return address onto the run-time stack when you return, you pop the return address from the stack reason: a function may be recursive When you call a function, inside the function body, you want to be able to access formal parameters variables local to the function variables belonging to an enclosing function (for nested functions) procedure P ( c: integer ) x: integer; procedure Q ( a, b: integer ) i, j: integer; begin x := x+a+j; end; begin Q(x,c); end; Activation Records (Frames) When we call a function, we push an entire frame onto the stack The frame contains the return address from the function the values of the local variables temporary workspace ... The size of a frame is not fixed need to chain together frames into a list (via dynamic link) need to be able to access the variables of the enclosing functions efficiently A B C top A Typical Frame Organization Static Links The static link of a function f points to the latest frame in the stack of the function that statically contains f If f is not lexically contained in any other function, its static link is null procedure P ( c: integer ) x: integer; procedure Q ( a, b: integer ) i, j: integer; begin x := x+a+j; end; begin Q(x,c); end; If P called Q then the static link of Q will point to the latest frame of P in the stack Note that we may have multiple frames of P in the stack; Q will point to the latest there is no way to call Q if there is no P frame in the stack, since Q is hidden outside P in the program The Code for Function Calls When a function (the caller) calls another function (the callee), it executes the following code: pre-call: do before the function call allocate the callee frame on top of the
您可能关注的文档
- OpenRequestforProposalProjectforDigitalArchives.ppt
- OpenAccessRepositories.ppt
- OM战略能力管理.ppt
- OpenSourceIndonesia.ppt
- OpenMP编程指南.ppt
- OperationsManagementInventoryManagement.ppt
- OPP及电话邀约培训.ppt
- OportunidaddeNegociosparalaIndustriaComercioyS.ppt
- OpportunitiesandChallengesintheManufacturingSector.ppt
- OptimumOmega如新华茂TM精选鱼油.ppt
文档评论(0)