一维指针通常用指针表示,其指向的地址是数组第一元素所在的内存地址,如下
1
2
|
int ary[4][5]; int (*aryp)[5] = ary; |
那么ary[4]相当于int(*aryp),以下理解如此,但参数传递需要知道实参所在 的一维个数,所以传递的时候应该传递多一个参数,子数组的引用可以理解 为(*p),那么取元素就是(*p)[i],如下
1
2
3
4
5
6
7
8
9
|
void printVal( int (*aryp)[5], int irowCount){ for ( int (*p)[5] = aryp; p != aryp + irowCount;p++) { for ( size_t i = 0; i < 5; i++) { cout << (*p)[i] << endl; } } } |
缺点就是:传递的时候还需要传递1维数组的个数。但扩展性强。
同样三维数组可以使用指向指针的指针的数组。通常很少用。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
原文链接:http://blog.csdn.net/qq285016127/article/details/46738563