作用域:

1、代码块儿作用域:

注意的是:这里面{}就代表一个代码块儿,里面的东西是独立的,不可被其他地方访问的。

2、函数作用域

3、文件作用域

先提一下

在当前有一个文件,main.c

还有一个文件比如叫做a.c

这个东西就属于文件作用域了,左边有一个变量叫做mainiii=0 在a.c里面有一个变量叫做aiii = 3.两个变量分属不同的文件,他们拥有各自的文件作用域,不能混用。

4、Auto:自动变量

一般不写就认为是auto类型的。我们通常定义的变量都属于 auto,他们都存放在 内存中,主要与register相区别。

5、Register 类型变量

使用方式: register int i=3;

是C语言建议把这个变量 i放到寄存器中,(通常情况下会放到寄存器中。但有时也不一定)用来提高当前变量的执行效率。因为是放入了寄存器,所以不提供取地址的服务。也就是说:

Register int i =3;

Int *p = &i;//这样做是不合法的,因为 已经把当前变量放入了寄存器中,在寄存器里面是没有地址的,也就没有办法取出。即使 这个变量没有真正被放到寄存器里面,也不能够去它的地址。

6、静态变量

只能在当前块儿内使用。但是在代码运行之初就完成初始化。并且一直保留直到程序结束。而非代码块执行结束。

静态变量还有一种用法,用来标识文件。

在当前目录下,main.c里面有aiii,在 a.c里面定义了 aiii=3;这样aiii拥有了全工程的范围,所以如果不希望别的地方也使用这个aiii,或者希望只在a.c里面使用aiii的话。就可以加static这个关键字。

现在有一个结果就是 aiii的值 不再是3了。

说明没有访问到a.c里面的内容。

那么0是什么情况呢?

0是由于 我们在main.c里面声明了一个 变量,这个 变量就是 全局的,全局变量默认初始化成0.所以我们得到了0的结果。

如果去掉  int aiii;的声明那么我们的访问就是 非法的了,因为 并不存在 这样一个aiii变量。

为了让我们的程序运行的更加合理,标明这个 变量到底是自己定义的,还是 外部引用的,就需要另外一个关键字extern。这个关键字在前面说,利用C++语言写一个DLL然后按照C语言编译也需要这样一个关键字。

但是这种写法是不可以的:

main.c里面说 外面有一个 aiii。在a.c里面说aiii仅当前文件可用。->其实没有aiii可用,这样编译器还在找这个 aiii,那么解析的结果就是 没有一个 靠谱的外部符号。

这个 时候 如果 去掉 static 那么运行就正常了。

并且也有合理的标识,告诉main.c 说 我这个 里面的 aiii就是 外面的,要么有,使用外面的,要么没有,报错。这样比起一个不确定的结果可0 可3的数字,要靠谱的多。

在C语言里面,写在函数外面的声明定义 就是 全局的,会默认赋初值0,如果我们没有自己定义初值的话。如果要共享这个 变量那就写 成 int i=[某个数]并且在其他的文件中写上extern表示 当前这个i是从别的文件中引入的变量;如果当前变量仅当前文件可用,那就加上static。表示 文件域。

C语言内存管理的更多相关文章

  1. Go语言内存管理(一)内存分配

    Go语言内存管理(一)内存分配 golang作为一种"高级语言",也提供了自己的内存管理机制.这样一方面可以简化编码的流程,降低因内存使用导致出现问题的频率(C语言使用者尤其是初学 ...

  2. C语言 内存管理(转)

     转自 https://blog.csdn.net/u011616739/article/details/61621815 C语言 内存管理 1.内存分区 C源代码进过预处理.编译.汇编和链接4步生成 ...

  3. 深入理解Linux C语言内存管理

    问题不能拖,我这就来学习一下吧,争取一次搞定. 在任何程序设计环境及语言中,内存管理都十分重要. 内存管理的基本概念 分析C语言内存的分布先从Linux下可执行的C程序入手.现在有一个简单的C源程序h ...

  4. C语言内存管理(转)

    伟大的Bill Gates 曾经失言: 640K ought to be enough for everybody — Bill Gates 1981 程序员们经常编写内存管理程序,往往提心吊胆.如果 ...

  5. iOS学习08之C语言内存管理

    本次主要学习和理解C语言中的内存管理 1.存储区划分 按照地址从高到低的顺序:栈区,堆区,静态区,常量区,代码区 1> 栈区:局部变量的存储区域 局部变量基本都在函数.循环.分支中定义 栈区的内 ...

  6. 深入理解C语言内存管理

    之前在学Java的时候对于Java虚拟机中的内存分布有一定的了解,但是最近在看一些C,发现居然自己对于C语言的内存分配了解的太少. 问题不能拖,我这就来学习一下吧,争取一次搞定. 在任何程序设计环境及 ...

  7. 一个C语言内存管理模块的实现

    C 内存管理模块的编写 C语言手动管理内存很困难,有时候很难发现内存泄漏,这两天看了一下里面有写了一个简单的内存管理模块,发现挺精巧,可以有效检测内存泄漏 原理很简单,就是把C的malloc函数分配的 ...

  8. Objective-C语言内存管理

    • Objective-C为每个对象提供一个内部计数器,这个计数器跟踪对象的引用次数.所有类都继承自 NSObject 的对象retain和release方法. 如果使用了new.alloc或copy ...

  9. 黑马程序员——OC语言 内存管理

    Java培训.Android培训.iOS培训..Net培训.期待与您交流! (以下内容是对黑马苹果入学视频的个人知识点总结) (一)计数器 每个对象内部都保存了一个与之相关联的整数,称为引用计数器,当 ...

  10. OC语言-05-OC语言-内存管理

    一.引用计数器 1> 栈和堆 栈 ① 主要存储局部变量 ② 内存自动回收 堆 ① 主要存储需要动态分配内存的变量 ② 需要手动回收内存,是OC内存管理的对象 2> 简介 作用 ① 表示对象 ...

随机推荐

  1. POJ 1655-Balancing Act(树形dp)

    题意: 求n个节点的树中哪个节点删除以后得到的最大连通分量最小. 分析:同上题 #include <map> #include <set> #include <list& ...

  2. codeforce 603B - Moodular Arithmetic

    题意:给出方程 f(kx%p)=kf(x)%p ,f:A->B,不同的映射函数f有几种,其中f,A,B值域为{0,1,2..p-1},p为素数(除了2),k为小于p的一个常数. 思路:明显是求循 ...

  3. volatile,可变参数,memset,内联函数,宽字符窄字符,国际化,条件编译,预处理命令,define中##和#的区别,文件缓冲,位域

    1.volatile: 要求参数修改每次都从内存中的读取.这种情况要比普通运行的变量需要的时间长. 当设置了成按照C99标准运行之后,使用volatile变量之后的程序运行的时间将比register的 ...

  4. HW6.21

    import java.util.Scanner; public class Solution { public static void main(String[] args) { Scanner i ...

  5. leetcode@ [300] Longest Increasing Subsequence (记忆化搜索)

    https://leetcode.com/problems/longest-increasing-subsequence/ Given an unsorted array of integers, f ...

  6. algorithm@ 大素数判定和大整数质因数分解

    #include<stdio.h> #include<string.h> #include<stdlib.h> #include<time.h> #in ...

  7. Use ALTER DATABASE to Move Databases

    Use ALTER DATABASE to Move Databases Follow Our Daily Tips •facebook.com/TechNetTips• twitter.com/Te ...

  8. Java TreeMap 源码解析

    继上篇文章介绍完了HashMap,这篇文章开始介绍Map系列另一个比较重要的类TreeMap. 大家也许能感觉到,网络上介绍HashMap的文章比较多,但是介绍TreeMap反而不那么多,这里面是有原 ...

  9. Android实例-OrientationSensor方向传感器(XE8+小米2)

    相关资料: <修复 XE8 for Android 方向传感器 headingX,Y,Z 不会动的问题>:http://www.cnblogs.com/onechen/p/4497282. ...

  10. 解决弹出的窗口window.open会被浏览器阻止的问题(自定义open方法)

    由于在使用window.open时,在很多情况下,弹出的窗口会被浏览器阻止,但若是使用a链接target='_blank',则不会,基于这一特点,自己封装了一个open方法: function ope ...