Skip to content

Latest commit

 

History

History
41 lines (29 loc) · 2.05 KB

45-自动存储连续性.md

File metadata and controls

41 lines (29 loc) · 2.05 KB

自动存储持续性

这个概念乍一看有些拗口,其实它很简单,指的是在函数定义中声明的变量的存储持续性是自动的:它们在程序开始执行其所属的函数或代码块时被创建,在执行完函数或代码块时,它们使用的内存被释放。

在默认情况下,我们在函数中声明的变量和函数的参数都是自动存储持续性,它的作用于为局部,没有链接性。

这里的链接性描述了名称如何在不同的单元之间共享,链接性为外部的名称可以在文件之间共享,链接性为内部的名称只能由一个车文件中的函数共享。自动变量的名称没有链接性,也就是不能共享。

这段话是一段专业性描述,看不太明白没有关系。简单理解,就是说如果我们在main函数当中声明了一个变量 a,并且在函数test当中也声明了一个同样的变量 a。两者之间是完全独立的,彼此不会有任何影响,因为它们只有在声明了它的函数中才能使用。

当程序执行test函数时,test中的 a 才被创建,当test执行结束,a 即被销毁。

其实变量的作用域的最小划分并不是函数,而是代码块。我们在代码块当中创建的变量,它的使用范围作用域就只有当前代码块。例如:

int main() {
	int a = 4;
    {
        int b = 10;
    }
}

我们在main函数当中定义了一个变量 a 和一个变量 b,但是这两个变量定义的位置不同。b 定义在了一个代码块(代码块使用花括号表示)当中,对于 a 来说,它的作用域是整个main函数,而 b 只在花括号当中生效。

更有意思的是下面这段代码:

int main() {
    int a = 4;
    {
        int a = 5;
        cout << a << endl;
    }
    cout << a << endl;
}

答案是输出的结果是 5 和 4,为什么呢?

因为内部和外部都有一个变量 a,当执行内部代码的时候,编译器隐藏了外部的定义。而程序离开代码块时,外部的定义又重新恢复。