全局变量和静态全局变量的地址有什么区别?
static int a=10;
int a=10;
他们的地址为什么不相同?

C语言中全局变量和静态全局变量的区别是什么?
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
3条回答 默认 最新
关注
我看其他答主都没有回答到问题的核心,我来深入给你解答一下。
对于面向过程的变成语言来说,全局变量和静态全局变量在使用上没有什么区别。但是在内存存储位置会有不同。这就涉及到可执行文件的运行内存模型。一般来说一个C/C++编译的程序占用的内存分为以下几个部分:
- 栈区(stack):由编译器自动分配释放 ,存放函数的参数值,局部变量的值等
- 堆区(heap):一般由程序员分配和释放, 用于存放大小不固定或大小会变动的数据
- 数据区:主要包括静态全局区和常量区
- 代码区:存放函数体的二进制代码。
其中全局变量和静态变量的存储放在数据区的静态全局区,初始化的全局变量和静态变量在一块区域, 未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。 程序结束后有系统释放。
你的问题
static int a=10; int a=10;
的地址为什么不同。因为这两个变量不同同时在一个程序里。你一定是2个程序跑了两次。程序每次运行时分配的内存都不一样,所以两次运行下来地址会不同,这很正常。
如果将int a=10; 改为int b=10;,在一个程序里输出,a,b的地址应该是挨着的。希望以上回答能解答你的疑惑。如果对你有帮助,记得采纳。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用