关于将数组地址赋给指针的问题
2017-06-27 09:42
405 查看
对于 int (*p)[3];
这条语句声明了:P是一个指向一个包含3个int值的数组的指针。
如下面对p赋值的例子:#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(){
int a[3] = {1, 2, 3};
int (*p)[3];
p = &a;
printf("%d %d %d",**p,*(*p+1),*(*p+2));这段程序的结果:
1 2 3
又比如:#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(){
int a[3][2]={{1,2},{3,4},{5,6}};
int (*p)[2];
p=&a[0];
printf("%d %d\n",**p,*(*p+1)); //数组第一行
printf("%d %d\n",**(p+1),*(*(p+1)+1)); //数组第二行
printf("%d %d\n",**(p+2),*(*(p+2)+1)); //数组第三行
1 2
3 4
5 6
由于无论是几维的数组在内存中都是占有逻辑连续的,线性的存储空间。所以:#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(){
int a[3][2]={{1,2},{3,4},{5,6}};
int (*p)[2];
p=a;
printf("%d %d\n",*(*p+2),*(*p+3));//由于数组是线性存储的,
}由于数组是线性存储,在内存中的逻辑位置如下:a[0][0]a[0][1]a[1][0]a[1][1]a[2][0]a[2][1]对于(*p+2)操作,指针按顺序移到了第三个int单元,也就指向第2行的第一个数据了。(详见《C Primer Plus》268页)
所以这段程序结果为:
3 4
总之,p指向一个数组,解引用后是一个数组的地址(解引用之后才会得到数组首元素的地址)。
同时也可以利用指针和数组的关系来让函数返回一个二维数组:
例如:#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int (*fun(int b[][2]))[2]
{
return b;
}
int main()
{
int a[3][2]={{1,2},{3,4},{5,6}};
int (*p)[2];
p = fun(a);
printf("%d %d\n",**p,*(*p+1));
printf("%d %d\n",**(p+1),*(*(p+1)+1));
printf("%d %d\n",**(p+2),*(*(p+2)+1));
return 0;
}
这段程序的结果是:
1 2
3 4
5 6
注意:
以int (*p)[2];方式定义时,p变量所指向的目标就同时被确定为一个长度是2的数组。而以int **p;方式定义时C仅仅将p解释为一个地址的地址,并不理解其指向的目标的数据结构(是一个长度是2的数组)。
这条语句声明了:P是一个指向一个包含3个int值的数组的指针。
如下面对p赋值的例子:#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(){
int a[3] = {1, 2, 3};
int (*p)[3];
p = &a;
printf("%d %d %d",**p,*(*p+1),*(*p+2));这段程序的结果:
1 2 3
又比如:#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(){
int a[3][2]={{1,2},{3,4},{5,6}};
int (*p)[2];
p=&a[0];
printf("%d %d\n",**p,*(*p+1)); //数组第一行
printf("%d %d\n",**(p+1),*(*(p+1)+1)); //数组第二行
printf("%d %d\n",**(p+2),*(*(p+2)+1)); //数组第三行
}这段程序结果为:
1 2
3 4
5 6
由于无论是几维的数组在内存中都是占有逻辑连续的,线性的存储空间。所以:#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(){
int a[3][2]={{1,2},{3,4},{5,6}};
int (*p)[2];
p=a;
printf("%d %d\n",*(*p+2),*(*p+3));//由于数组是线性存储的,
}由于数组是线性存储,在内存中的逻辑位置如下:a[0][0]a[0][1]a[1][0]a[1][1]a[2][0]a[2][1]对于(*p+2)操作,指针按顺序移到了第三个int单元,也就指向第2行的第一个数据了。(详见《C Primer Plus》268页)
所以这段程序结果为:
3 4
总之,p指向一个数组,解引用后是一个数组的地址(解引用之后才会得到数组首元素的地址)。
同时也可以利用指针和数组的关系来让函数返回一个二维数组:
例如:#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int (*fun(int b[][2]))[2]
{
return b;
}
int main()
{
int a[3][2]={{1,2},{3,4},{5,6}};
int (*p)[2];
p = fun(a);
printf("%d %d\n",**p,*(*p+1));
printf("%d %d\n",**(p+1),*(*(p+1)+1));
printf("%d %d\n",**(p+2),*(*(p+2)+1));
return 0;
}
这段程序的结果是:
1 2
3 4
5 6
注意:
以int (*p)[2];方式定义时,p变量所指向的目标就同时被确定为一个长度是2的数组。而以int **p;方式定义时C仅仅将p解释为一个地址的地址,并不理解其指向的目标的数据结构(是一个长度是2的数组)。
相关文章推荐
- 关于字符串 字符数组 字符型指针的问题
- 关于二维数组地址和指针之间赋值的问题
- 关于C数组与指针的关系(主要是长度首地址内容)
- 数组和指针地址移动问题
- 关于可变数组或字典的拷贝内容的问题(非拷贝指针)
- C/C++中关于地址、指针和引用变量的学习笔记(二) : 数组
- 关于数组做函数形参和指针做函数形参的问题
- C/C++拾遗:关于数组的指针和数组元素首地址的一道经典题
- 关于指针地址的问题
- 关于数组和指针的一些基本问题
- 关于指针数组的初始化和输入 问题
- 关于数组的&a[0]和&a及指针访问的问题
- 小小的C语言问题指针数组赋值----关于指针和数组。
- QP实现之函数指针数组无法获取正确地址的问题
- 关于函数字符数组调用的问题(没有搞清指针的概念)
- 关于数组地址,指针
- php中关于数组的指针移动问题!
- 关于字符指针和字符数组初始化的问题
- C/C++拾遗(一):关于数组的指针和数组元素首地址的一道经典题
- 关于C 多维数组与指针的问题