当前位置:首页 > 学习资源 > 讲师博文 > static全局变量和普通全局变量的区别

static全局变量和普通全局变量的区别 时间:2024-05-11      来源:华清远见

在开始探讨static全局变量和普通全局变量的区别之前,我们先来熟悉一下,用户内存分区。

一、用户空间

通过对用户空间内存划分的了解,现在我们来探讨一下,static全局变量和普通全局变量的

区别:

全局变量的说明之前再加以static 就构成了静态的全局变量。

一、存储位置

全局变量本身就是静态存储方式,静态全局变量当然也是静态存储方式。这两者在存储方式上并无不同。

二、作用域

static全局变量和普通全局变量两者的区别在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的。而静态全局变量则限制了其作用域,即只在定义该变量的源文件内有效,在同一源程序的其它源文件中不能使用它。由于静态全局变量的作用域局限于一个源文件内,只能为该源文件内的函数公用,因此可以避免在其它源文件中引起错误。

总结:

全局变量的作用域:整个源程序都可使用。

Static修饰的全局变量的作用域:限于当前源文件内使用。

三、初始化

1.静态变量的初始化是在编译时进行,变量的赋值是在函数或程序运行时进行。

2.静态变量只初始化一次,但可以通过赋值的方式多次修改静态变量的值。

3.全局变量和静态变量在进入main 前被初始化

上一篇:static修饰的函数和普通函数有什么区别

下一篇:如何应用box-cox变换来帮助模型性能

戳我查看嵌入式每月就业风云榜

点我了解华清远见高校学霸学习秘籍

猜你关心企业是如何评价华清学员的

干货分享
相关新闻
前台专线:010-82525158 企业培训洽谈专线:010-82525379 院校合作洽谈专线:010-82525379 Copyright © 2004-2024 北京华清远见科技发展有限公司 版权所有 ,京ICP备16055225号-5京公海网安备11010802025203号

回到顶部