全局变量和静态全局变量的地址有什么区别?
static int a=10;
int a=10;
他们的地址为什么不相同?
我看其他答主都没有回答到问题的核心,我来深入给你解答一下。
对于面向过程的变成语言来说,全局变量和静态全局变量在使用上没有什么区别。但是在内存存储位置会有不同。这就涉及到可执行文件的运行内存模型。一般来说一个C/C++编译的程序占用的内存分为以下几个部分:
其中全局变量和静态变量的存储放在数据区的静态全局区,初始化的全局变量和静态变量在一块区域, 未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。 程序结束后有系统释放。
你的问题static int a=10; int a=10;
的地址为什么不同。因为这两个变量不同同时在一个程序里。你一定是2个程序跑了两次。程序每次运行时分配的内存都不一样,所以两次运行下来地址会不同,这很正常。
如果将int a=10; 改为int b=10;,在一个程序里输出,a,b的地址应该是挨着的。
希望以上回答能解答你的疑惑。如果对你有帮助,记得采纳。
在同一个源文件内,
static int a=10;
int a=10;
是有错误的,在一个代码块内,不能同时定义两个同名的变量。
它们的主要区别在于作用域。静态全局变量只作用于当前这个文件,全局变量作用于整个项目。
他们都存储在静态区域。参考代码如下:
#include <stdio.h>
static int a = 10;
int b = 20;
int main()
{
printf("&a=%p\n",&a);
printf("&b=%p\n",&b);
return 0;
}
运行结果:
&a=0x100894014
&b=0x100894010
没啥区别 静态变量和全局变量本身就在一个区域