EasyC++,自动存储持续性

 

大家好,动存我是储持梁唐。

想要追求更好阅读体验的续性同学,可以点击「阅读原文」访问github仓库。动存

自动存储持续性

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

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

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

这段话是一段专业性描述,看不太明白没有关系。简单理解,就是说如果我们在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,当执行内部代码的时候,编译器隐藏了外部的定义。而程序离开代码块时,外部的定义又重新恢复。

本文转载自微信公众号「Coder梁」,可以通过以下二维码关注。转载本文请联系Coder梁公众号。

滇ICP备2023000592号-31