黑马程序员技术交流社区

标题: C语言中数组在内存中的存储细节 [打印本页]

作者: 闫跃文    时间: 2014-9-28 01:31
标题: C语言中数组在内存中的存储细节
数组在内存中的存储细节:

1、数组在内存中存储单元是连续(连续存储)
2、每个元素a[0]、a[1]分别代表对应存储的数据的首地址
3、对于整型的数组来说,每个元素之间相差4个字节
       char                       1个字节
       float                      4个字节
       double                     8个字节

4、数组名,不是一个int类型的变量,他是一个地址(数组的首地址)

    注意:int x[]={1,2}  int修饰的是数组的每个元素是int类型,不是修饰x是int类型

    数组的首地址 == 数组名 == 数组的第一个元素的首地址

    以int x[]={1,2} 为例:
   
     x这个数组的首地址  == x == x[0]元素的首地址

5、数组内部的各元素的地址是连续的,但是不同的数组之间的地址可以不连续。

6、计算数组的长度

    长度 = 首先我们得先计算整个数组在内存中占用的存储单元 / 然后获取数组中每个元素的类型所占用的字节数

7、我们可以通过数组的名称,计算出数组每一个元素的地址。

    数组名+下标*sizeof(元素的类型)

    int x[3]={1,2,3}  

    x[2]的地址 = x + 2*sizeof(int)




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2