c++ 普通数组原理是什么

c++ 普通数组的原理是什么 它和二级指针的关联有是什么请告诉我一下

一个普通数组的定义 例如 int a[10]; 它的意义就是开劈了10个整形的空间并且是连续的线性结构。我们访问数组元素有两用访问形式。

1、指针,我们可以把数组名当成数组首元素的地址。+0就是第一个元素地址,+1就是第二个元素地址。再对这些地址解引用就是访问数组元素,例如:*(a+0),*(a+1)

2、下标,以 数组名[数字] 的形式来访问数组元素。例如a[0]是第一个元素,a[1]是第二个元素。

至于你说的二级指针,也可以叫指针的指针。二级指针的指向是另一个指针所存在的地址空间。

例如:

int a = 1;
int *p = &a;//一级指针
int **pp = &p//二级指针

我估计楼主是被 int **a = {......}; 这种数组结构所迷惑了。

我们定义一个数组的时候可以不给它规定大小,以一个空方括号结束。
例如:int a[]={......};
同理,从上面讲的指针下标访问得知,我们也可以这样定义 int *a={......};

上面这个数组的意思是定义一个名字为a的数组,存放的元素类型为int 。
那么,再加上一个*呢? 分解来看
(int *) *a ={......};
一目了然,意思即为定义一个名字为a的数组,数组元素的类型为int *

内存上连续的线性结构

二级指针对应的是数组的数组,而数组相当于这个数组的头指针,而下标表示它的偏移量。
比如
p[10]其实就是*(p+10)
这也是为什么在C语言里,你甚至可以写 10[p],看上去很奇怪的写法,难道10也是数组,这说明数组只是一个简单的障眼法,其实它是*(10 + p),因为*(10 + p)也是一样的。