实例说明heap和stack在程序运行中的作用

http://www.cs.jcu.edu.au/Subjects/cp2003/1997/foils/heapAndStack/heapAndStack.html

Heap vs. Stack

 

  • visual depiction of run-time storage
    external
  • heap
    • freelist - list of free space
    • on allocation - memory manager finds space and marks it as used changing freelist
    • on deallocation - memory manager marks space as free changing freelist
    • memory fragmentation - memory fragments into small blocks over lifetime of program
    • garbage collection - coalesce fragments, possibly moving objects (must be careful of pointers when moving!)
  • stack
    • clean and efficient support for nested functions and recursion
    • central concept is stack frame (also called activation record), includes
      • visual depiction of frame
        external
      • parameters
      • return address - where to begin execution when function exits
      • dynamic link - pointer to caller's stack frame
      • static link - pointer to lexical parent (for nested functions)
      • return value - where to put the return value
      • local variables
      • local work space - for temporary storage of results
    • function call - push stack frame
    • function exit - pop stack frame
    • visual depiction of stack calls
      external
  • example
    int x;                 /* static storage */
    
    void main() {
       int y;              /* dynamic stack storage */
       char *str;          /* dynamic stack storage */
      
       str = malloc(100);  /* allocates 100 bytes of dynamic heap storage */
    
       y = foo(23);
       free(str);          /* deallocates 100 bytes of dynamic heap storage */
    }                      /* y and str deallocated as stack frame is popped */
    
    int foo(int z) {       /* z is dynamic stack storage */
       char ch[100];     /* ch is dynamic stack storage */
    
       if (z == 23) foo(7);
       
       return 3;           /* z and ch are deallocated as stack frame is popped,
                              3 put on top of stack  */
    }
  • at the start of the program
    external
  • after the first call to foo
    external
  • after the second call to foo
    external

Dead Objects

 

  • storage objects in stack storage die (are deallocated) when the stack frame is popped.
  • storage objects in heap storage must be explicitly killed in C, but in other languages are implicitly killed when they are no longer referenced.
    /* C example */
      char *str;
      str = malloc(100);  /* allocate 100 byte storage object in heap storage 
                             put the pointer to it into str */
      free(str);          /* kill the allocated storage object */
  • the freelist is a list of free areas in heap storage. When an object is allocated, the freelist is searched to find a big enough free area, and then the list is updated to mark that space as no longer free. When an object is killed, the space for the object is added to the freelist. Garbage collection coalesces the heap storage areas pointed to by the freelist.
  • dangling reference - pointer to a dead object
    /* C example */
      char *str;
      str = malloc(100);  /* allocate 100 byte storage object in heap storage 
                             put the pointer to it into str */
      free(str);          /* kill the allocated storage object */
      *str = 'h';         /* str is now a dangling reference! attempt to put
                             the character 'h' to what is pointed at by str,
                             but str points to a dead object */

Persistent Variables

A persistent varible is a variable that lives beyond the execution of a program.

{ Pascal Example }
   program curt(a_file_name)  { a_file_name is a persistent file variable! }
     ....
   end.
But why should files be different than other types of variables? This is a violation of the type completeness principle. Research is underway to add persistence to programming languages.  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值