虽然我一直知道它们两个的区别,但是分不清名字应该是叫哪个。 这里区别一下。
顾名思义:这是个数组,数组里面的元素都是指针。
int *arr[10];
这个等同于 int *(a[4])
因为*
的优先级比较低,所以没有括号的时候,是arr和[10]
先结合,变成一个数组,然后这个数组的元素是整型指针。
这个初始化要按照数组的方式来。
for ( int i = 0; i < 10; i++){
a[i] = (int *)malloc( 5 * sizeof(int) );
}
这样就是循环遍历每一个数组元素,对给指针申请空间,每个指针都指向一个具有5个int
大小的内存。
这个时候,你就可以赋值了。
for ( int i = 0; i < 10; i++){
for (int j = 0; j < 5; j++){
a[i][j] = 0;
}
}
这个时候就把所有元素都赋值为0了。
注意:因为数组的每个元素都是一个指针。所以当你访问
a[0][6]
的时候是不会报错的。但是输出的值是未定义的,比较危险。
这个就是说我是一个指针,指针指向了一个数组。
int (*arr)[10];
这里让*和arr
结合,成为一个指针,这个指针指向了一个int
型的具有10个元素的数组。
对于这个的初始化我个人认为相对不好理解。
第一中初始化方法:
int temp[4][10] = {};
//方法1
int (*arr)[10] = temp; // 正确
//方法2
int (*array)[10];
array = temp; //正确
//方法3
int (*array_m)[11], (*array_n)[9];
array_m = temp; // error
array_n = temp; //error
//方法4
for( int i =0;i < 4; i++){
arr = &temp[i]; // 正确
arr++;
}
arr -= i; // 一定要减去i 才能回到最初始的位置。
在这里只有方法1, 2, 4是正确的,3里面的两种都会报错。
这里重点说一下方法4. 为什么
arr++
会直接接收下一个int [10]
,是因为arr
是指向一个int [10]
的数组,也就是说当arr++
的时候,这个指针会向前移动10个int的长度的内存。
以上就是区别了。我平时基本上在二维数组里只用指针数组,很少用数组指针。
因为指针数组比较好理解,但是大家尽量要注意边界问题。
版权声明:本文为博主原创文章,未经博主允许不得转载。
原文地址:http://blog.csdn.net/alps1992/article/details/48131775