C语言中,static静态变量的应用

static静态变量的使用
1.全局静态变量
在全局变量之前加上关键字static,全局变量就被定义成为一个全局静态变量。
1)内存中的位置:静态存储区(静态存储区在整个程序运行期间都存在)
2)初始化:未经初始化的全局静态变量会被程序自动初始化为0
3)作用域:全局静态变量在声明他的文件之外是不可见的。准确地讲从定义之处开始到文件结尾。
好处:
定义全局静态变量的好处:
(1)不会被其他文件所访问,修改
(2)其他文件中可以使用相同名字的变量,不会发生冲突。
2.局部静态变量
在局部变量之前加上关键字static,局部变量就被定义成为一个局部静态变量。
1)内存中的位置:静态存储区
2)初始化:未经初始化的全局静态变量会被程序自动初始化为0
3)作用域:作用域仍为局部作用域,当定义它的函数或者语句块结束的时候,作用域随之结束。
注:当static用来修饰局部变量的时候,它就改变了局部变量的存储位置,从原来的栈中存放改为静态存储区。但是局部静态变量在离开作用域之后,并没有被销毁,而是仍然驻留在内存当中,直到程序结束,只不过我们不能再对他进行访问。
当static用来修饰全局变量的时候,它就改变了全局变量的作用域(在声明他的文件之外是不可见的),但是没有改变它的存放位置,还是在静态存储区中。

#include <stdio.h>
#include <stdlib.h>

int fun(int x, int y){
	static int m = 0;
	static int i = 2;
	i += m + 1;
	m = i + x + y;
	return m;
}

void main(){
	int j = 4;
	int m = 1;
	int k;
	k = fun(j, m);
	printf("%d\n", k);
	k = fun(j, m);
	printf("%d", k);
	return 0;
}

运行结果为8和17。
函数中的静态变量m的作用域就在函数开始到结束,但是当函数调用结束后,m的值并没有销毁,而保留在内存中。第二次调用fun()函数时,给的参数为fun(4,1),因为静态变量的作用域并没有包含这段程序,进入函数后m的值变为上次运行结束后的最后值8。故最后得到次运行结果。此段为自己理解,若有不严谨或错误,请见谅。

发布了77 篇原创文章 · 获赞 23 · 访问量 7561

猜你喜欢

转载自blog.csdn.net/Hots3y/article/details/98781804