#include <stdio.h>
int f(void);
int gAll = 12;
int main(int argc,char const *argv[])
{
printf("in %s gAll = %d\n",__func__,gAll);//__func__ 是一个数组,表示该段代码位于哪个函数
f();
printf("agn in %s gAll = %d\n",__func__,gAll);
return 0;
}
int f(void)
{
printf("in %s gAll = %d\n",__func__,gAll);
gAll += 2;
printf("agn in %s gAll = %d\n",__func__,gAll);
return 0;
}
没有做初始化的全局变量会得到0值,指针会得到NULL值,只能用编译时刻已知的值来初始化全局变量,它们的初始化发生在main函数之前。
#include <stdio.h>
int f(void);
int gAll;
int main(int argc,char const *argv[])
{
printf("in %s gAll = %d\n",__func__,gAll);
f();
printf("agn in %s gAll = %d\n",__func__,gAll);
return 0;
}
int f(void)
{
printf("in %s gAll = %d\n",__func__,gAll);
gAll += 2;
printf("agn in %s gAll = %d\n",__func__,gAll);
return 0;
}
全局变量被隐藏的情况:
如果函数内部存在与全局变量同名的变量,则全局变量会被隐藏
在函数f中做出如下改动:
int f(void)
{
int gAll = 1;
printf("in %s gAll = %d\n",__func__,gAll);
gAll += 2;
printf("agn in %s gAll = %d\n",__func__,gAll);
return 0;
}
会得到以下结果。
在更小的程序块内可以定义出覆盖大程序块内的同名变量。
静态本地变量:
在本地变量定义时加上static修饰符就成为静态本地变量,即使离开了定义静态本地变量的程序块,静态本地变量也会一直存在并保存其值,它的初始化只会在第一次进入这个函数时做。
#include <stdio.h>
int f(void);
int main(int argc,char const *argv[])
{
f();
f();
f();
return 0;
}
int f(void)
{
static int all = 1;
printf("in %s all = %d\n",__func__,all);
all += 2;
printf("agn in %s all = %d\n",__func__,all);
return 0;
}
静态本地变量是特殊的全局变量,它们都是在相同的内存区域内,static在这里是局部作用域的意思
#include <stdio.h>
int f(void);
int gAll;
int main(int argc,char const *argv[])
{
f();
return 0;
}
int f(void)
{
int k;
static int all = 1;
printf("&gAll = %p\n",&gAll);
printf("&all = %p\n",&all);
printf("&k = %p\n",&k);
return 0;
}