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

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.

主站蜘蛛池模板: 册亨县| 永昌县| 镇远县| 松溪县| 长子县| 湄潭县| 丹寨县| 保定市| 福贡县| 莱西市| 保定市| 石棉县| 彩票| 漳州市| 黎平县| 格尔木市| 平潭县| 临颍县| 舞阳县| 襄樊市| 成都市| 雅安市| 治县。| 开封市| 英山县| 定襄县| 宣化县| 平原县| 昌图县| 沧州市| 北京市| 比如县| 九江市| 巍山| 西昌市| 青阳县| 河间市| 库尔勒市| 论坛| 衢州市| 广汉市|