如何定义一个指针数组 定义一个指针指向数组
大家好,我是小典,我来为大家解答以上问题。如何定义一个指针数组,定义一个指针指向数组,很多人还不知道,现在让我们一起来看看吧!
1、指针数组定义int*p[n];
2、[]优先级高,先与p结合成为一个数组,再由int*说明这是一个整型指针数组,它有n个指针类型的数组元素。这里执行p+1时,则p指向下一个数组元素,
3、这样赋值是错误的:p=a;因为p是个不可知的表示,只存在p[0]、p[1]、p[2]...p[n-1],而且它们分别是指针变量可以用来存放变量地址。但可以这样*p=a;这里*p表示指针数组第一个元素的值,a的首地址的值。
4、数组指针定义int(*p)[n];
5、()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长。也就是说执行p+1时,p要跨过n个整型数据的长度。
6、如要将二维数组赋给一指针,应这样赋值:
7、int a[3][4];
8、int(*p)[4];//该语句是定义一个数组指针,指向含4个元素的一维数组。
9、p=a;//将该二维数组的首地址赋给p,也就是a[0]或&a[0][0]
10、p++;//该语句执行过后,也就是p=p+1;p跨过行a[0][]指向了行a[1][]
11、扩展资料:
12、与数组指针关系
13、数组指针是指向数组首元素的地址的指针,其本质为指针(这个指针存放的是数组首地址的地址,相当于2级指针,这个指针不可移动);指针数组是数组元素为指针的数组,其本质为数组。
14、例如:*p[2]是指针数组,实质是一个数组,里面的两个元素都是指针,[]的优先级比*的优先级高,p先与[]结合,形成数组p[2],有两个元素的数组,再与*结合,表示此数组是指针类型的,每个数组元素相当于一个指针变量
15、与二维数组对比
16、二维数组:如char string_1[10][10]只要定义了一个二维数组,无论赋不赋值,系统都会给他分配相应空间,而且该空间一定是连续的。其每个元素表示一个字符。我们可以通过指定下标对其元素进行修改。
17、指针数组:如char*str_B[5]系统至少会分配5个连续的空间用来存储5个元素,表示str_B是一个5个元素的数组,每个元素是一个指向字符型数据的一个指针。
18、如果我做这样的定义:
19、char a[3][8]={"gain","much","strong"};
20、char*n[3]={"gain","much","strong"};
21、他们在内存的存储方式分别如右图所示,可见,系统给数组a分配了
22、3×8的空间,而给n分配的空间则取决于具体字符串的长度。
23、此外,系统分配给a的空间是连续的,而给n分配的空间则不一定连续。
24、由此可见,相比于比二维字符数组,指针数组有明显的优点:一是指针数组中每个元素所指的字符串不必限制在相同的字符长度;二是访问指针数组中的一个元素是用指针间接进行的,效率比下标方式要高。但是二维字符数组却可以通过下标很方便的修改某一元素的值,而指针数组却无法这么做。
25、举例编辑
26、数组指针:
27、#include<stdio.h>
28、int main()
29、{
30、char c[][4]={"哥","哥","我","岸","上","走"};//UTF-8:一个汉字=3个字节
31、char(*p)[4];
32、int i;p=c;//将指针定位于c[0]
33、for(i=0;i<=5;i++)
34、{
35、printf("%s,",*(p+i));//或者将*(p+i)替换成*p++
36、}
37、printf(" ");
38、for(i=5;i>=0;i--)
39、{
40、printf("%s,",*(p+i));//或者将*(p+i)替换成*--p
41、}
42、return 0;
43、}
44、指针数组:
45、#include<stdio.h>
46、int main()
47、{
48、int i;
49、char*pch[6]={"妹","妹","你","坐","船","头"};
50、for(i=0;i<6;i++){
51、printf("%s,",pch<i>);
52、}
53、printf(" ");
54、for(i=5;i>=0;i--){
55、printf("%s ",pch<i>);
56、}
57、return 0;
58、}
59、参考资料:
60、搜狗百科——指针数组
本文到此讲解完毕了,希望对大家有帮助。