多维数组的组织结构和内存分布规律

1  数组是什么?

多个相同数据类型变量构成的集合就是数组,比如int a[2]; int b[6]。

2  为什么C语言要设计数组这个概念?

因为很多场合下需要把一堆相同类型的数据存放在内存中,而数组正好可以满足这个要求。

3 为什么C语言要设计多维数组,比如二维数组,三维数组?

理论上,数据都可以存放在一维数组中,但是这样存放毫无层次,毫无规律,数据的访问也会非常的复杂。于是设计有层次规律的数组就很有必要了,所谓有层次规律的数组指的就是有结构性的数组。先看看下面这个图:

多维数组的组织结构和内存分布规律

 一个学校如果各年级的班级毫无次序的随便安排,那么必然造成管理效率低下的结果,老师走错教室,学生进错班级等等。如果按照上图组织学校各年级班级,那么学校运作将会非常高效。同理,要把有条理有结构性的数据存放在内存中,就必须设计有结构性的数组。

4 多维数组在内存中的存储结构如何?

4.1 二维数组在内存中的存储情况:

二维数组:char table[3][4]={{"a1","a2","a3","a4"},{"b1","b2","b3","b4"},{"c1","c2","c3","c4"}};

该二维数组在内存中的存储安排:

多维数组的组织结构和内存分布规律

该二维数组的组织架构图:

多维数组的组织结构和内存分布规律

4.2 三维数组在内存中的存储情况:

三维数组:char table[2][3][4]=

                    {

                          {{"a1","a2","a3","a4"},{"b1","b2","b3","b4"},{"c1","c2","c3","c4"}},

                          {{"d1","d2","d3","d4"},{"e1","e2","e3","e4"},{"f1","f2","f3","f4"}},

                    }

该三维数组在内存中的存储安排:

多维数组的组织结构和内存分布规律

该三维数组的组织架构图: 

多维数组的组织结构和内存分布规律

5 总结

5.1 多维数组靠左边的为高维,靠右边的为低维。

5.2 多维数组的组织架构类似于“学校-年级-班级-学生”的金字塔型架构

5.3 多维数组在内存中的分布是连续的。

多维数组的组织结构和内存分布规律

换句话说,最高维度为L,次高纬度为M,最低纬度为N;高层领导为L,中层领导为M,基层员工为N。