官术网_书友最值得收藏!

What is meant by the stack?

The simplest way to think about the stack is to consider memory as a series of boxes. For these examples, think of the boxes in groups of four: the function name, the address, the variable name, and the value. Here's a main function with a single local variable:

    fn main() 
    { 
        let i = 32; 
    } 

The stack boxes will look like this:

A slightly different example is as follows:

    fn second() 
    { 
        let a = 32; 
        let b = 12; 
    } 
    fn main() 
    { 
        let d = 100; 
    } 

Here, we will have two unconnected stack boxes. Since the second function is never called, we never actually allocate memory on the stack for it. The memory allocations are therefore exactly same as in the first example.

Our third example is where we have the main function call to the second function; in this case, we actually reserve memory for the second function:

    fn second() 
    { 
        let a = 32; 
        let b = 12; 
    } 
    fn main() 
    { 
        let d = 100; 
        second(); 
    } 

In terms of our stack boxes, we have the following:

The variable from the main function has the address of 0 as it is from the top frame-the frame that calls the other function. The value for the address is purely for this example; it can be anywhere and, typically, different types require a different amount of the stack to hold them. For instance, if the number type is 4 bytes in length, the address will be the base address of the stack to store d, then the address + 4 for b, and finally the address + 8 for a.

Once foo has returned, the stack reverts to this:

As soon as the main function has finished, the stack is empty.

This stacking continues for as many different functions as the application has, and they always work in the same way.

主站蜘蛛池模板: 阳泉市| 贵德县| 文化| 南陵县| 西充县| 荥阳市| 安陆市| 滨海县| 沁源县| 霍山县| 伊宁县| 广东省| 房产| 将乐县| 乡城县| 龙泉市| 开远市| 缙云县| 弥勒县| 河津市| 汕头市| 岑巩县| 兴安盟| 漯河市| 锡林郭勒盟| 同仁县| 恭城| 兰西县| 青河县| 调兵山市| 盐边县| 阳泉市| 唐海县| 长阳| 甘孜| 来宾市| 荔波县| 苍梧县| 宿州市| 常熟市| 杭锦后旗|