为什么一维数组可以当作指针传参
如果说原理 只能说是C语言为了方便 做的一种规定
C语言中, 数组名,其值为数组首地址
而地址, 正是指针的含义
所以 一维数组 可以当做指针传值。
这样才更方便
毕竟不管是数组,还是指针,都可以认为是一段连续的内存。
为什么二维数组不可以当作指针传参
二维数组名即数组地址,指向首行地址,表面上看,行地址即一维数组指针,而数组名指向行就应该是指针的指针,但是必须注意指针也是有类型的,类型不同数据宽度也不同。
如果a[10][10],假设int **p=a; 那么要对行递增执行p++时,编译器如何知道列宽?因为int **是指指向一个 int 类型的指针,32位系统中int 的宽度为4字节,即地址宽度是4字节,因此p将指向下一个元素(整数指针),也就是p递增了4字节,而不是10个int型数据的宽度,这就错位了。
所以a[10][10]的地址类型不是简单的指针的指针,而是行指针的指针,而行宽是由你定义的数组列数和元素类型所决定,int类型就是410=40个字节。这叫数据对齐。因此编译器在转换数组名时,会根据对齐要求而确定相应的指针类型,所以a的地址类型应该是int ()[10],而不是int **。
所以应该这样:int (*p)[10]=a;
其含义为,p是一个指向(含10个int类型元素的一维数组或行的)指针,其实本质上任何指针都是4字节(32位系统),你完全可以将一种指针类型强制转为任何其他类型,那为什么还要区分指针类型,就是为了指针运算时实现数据对齐,准确定位。
本文解析了一维数组作为指针传参的原理,强调了C语言中数组名等价于首地址。同时揭示了二维数组不能直接作为指针的原因,涉及数据对齐和指针类型转换。关键点在于理解指针类型与数据宽度的关系和数组地址的正确表示。
1798

被折叠的 条评论
为什么被折叠?



