下面详细分析和介绍静态全局变量和普通全局变量的区别。有需要的朋友可以过来参考一下,希望能帮到你。
(1)1)静态全局变量和普通全局变量有什么区别?(2)2)静态局部变量和普通局部变量有什么区别?(3)3)静态函数和常用函数作用域有什么区别?(4)4)静态函数和普通函数有什么区别?
(1)1)静态全局变量和普通全局变量有什么区别?
答:
全局变量的描述以static开头,形成静态全局变量。全局变量本身就是静态存储方法,静态全局变量也是静态存储方法。两者在存储方式上没有区别。虽然两者的区别在于非静态全局变量的作用范围是整个源程序,但是当一个源程序由多个源文件组成时,非静态全局变量在每个源文件中都是有效的。但静态全局变量限制了它的作用域,即它只在定义该变量的源文件中有效,不能在同一源程序的其他源文件中使用。因为静态全局变量的范围被限制在一个源文件中,它们只能被那个源文件中的函数共享,所以它可以避免在其他源文件中引起错误。从上面的分析可以看出,把局部变量改成静态变量,改变了它的存储方式,也就是它的生存期。把全局变量改成静态变量,改变了它的作用域,限制了它的使用范围。(2)2)静态局部变量和普通局部变量有什么区别?
答:
静态局部变量只初始化一次,下一次以最后一次结果值为准;(3)3)静态函数和普通函数作用域有什么区别?
答:
仅在本文件中。只在当前源文件中使用的函数应该描述为静态函数,应该在当前源文件中描述和定义静态函数。对于可以在当前源文件之外使用的函数,应该在一个头文件中声明,并且使用这些函数的源文件应该包含这个头文件。(4)4)静态函数和普通函数有什么区别?内存中只有一个