C语言中全局变量和静态全局变量的区别是什么?

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

我看其他答主都没有回答到问题的核心,我来深入给你解答一下。

对于面向过程的变成语言来说,全局变量和静态全局变量在使用上没有什么区别。但是在内存存储位置会有不同。这就涉及到可执行文件的运行内存模型。一般来说一个C/C++编译的程序占用的内存分为以下几个部分:

  1. 栈区(stack):由编译器自动分配释放 ,存放函数的参数值,局部变量的值等
  2. 堆区(heap):一般由程序员分配和释放, 用于存放大小不固定或大小会变动的数据
  3. 数据区:主要包括静态全局区和常量区
  4. 代码区:存放函数体的二进制代码。

其中全局变量和静态变量的存储放在数据区的静态全局区,初始化的全局变量和静态变量在一块区域, 未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。 程序结束后有系统释放。

你的问题
static int a=10; int a=10;
的地址为什么不同。因为这两个变量不同同时在一个程序里。你一定是2个程序跑了两次。程序每次运行时分配的内存都不一样,所以两次运行下来地址会不同,这很正常。
如果将int a=10; 改为int b=10;,在一个程序里输出,a,b的地址应该是挨着的。

希望以上回答能解答你的疑惑。如果对你有帮助,记得采纳。

  1. 在同一个源文件内,
    static int a=10;
    int a=10;
    是有错误的,在一个代码块内,不能同时定义两个同名的变量。

  2. 它们的主要区别在于作用域。静态全局变量只作用于当前这个文件,全局变量作用于整个项目。

  3. 他们都存储在静态区域。参考代码如下:

#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

没啥区别 静态变量和全局变量本身就在一个区域