总结:
一维和多维数组的数组名,是一个指针,这个指针指向的是该数组的第一个“元素”。
例1:
char *p0;
char buf0[2] = {1};
p0 = buf0;
char *p0; 表示定义一个指向char型的指针。便于理解可以写成char (*p0); *p0是指针,指向 char类型。
例2:
char (*p1)[4];
char buf1[2][4] = {1};
p1 = buf1;
printf(“%d:size(p1):%d\n”, LINE,(int)(p1+1) - (int)p1);
printf(“%d:size(buf1):%d\n”, LINE, (int)(buf1+1) - (int)buf1);
char (p1)[4];表示定义一个char ()[4]型的指针。
(int)(p1+1) - (int)p1的值为4;
(int)(buf1+1) - (int)buf1) 的值为4;
buf1指向它的第一个元素buf1[0], buf1[0]的类型是char (*)[4]。Buf1++就是指向它的第二个元素buf[1]。数组本身是没有多维的概念。只有一维的概念。
例3:
char (*p2)[2][4];
char buf2[2][2][4] = {1};
p2 = buf2;
p2 = &buf2[1];
printf(“%d:size(p2):%d\n”, LINE, (int)(p2+1) - (int)p2);
printf(“%d:size(buf2):%d\n”,LINE, (int)(buf2+1) - (int)buf2);
printf(“%d:size(buf2[1]):%d\n”, LINE, (int)(buf2[1]+1) - (int)buf2[1]);
同理分析,p2是指向char (*)[2][4]型的指针。(int)(p2+1) - (int)p2的值为8.
Buf2是指向它的第一个元素buf2[0], buf2[0]的类型是char (*)[2][4]。
(int)(buf2[1]+1) - (int)buf2[1]的值为4
buf2[1]的类型是char ()[4]. &buf2[1]类型是char ()[2][4].
要注意:char* a[4]; 和 char (a)[4]的区别, 一个类型是char , 一个类型是char (*)[4]
#include <stdio.h>
#include <unistd.h>
char buf[2][4][2] = {
{{1,2},{3,4},{5,6},{7,8}},
{{11,12},{13,14},{15,16},{17,18}}
};
/*函数返回数组的3种方式*/
//第一种方式,直接把数组指针强转void *返回,使用的时候再强转成真实的类型
void* fun()
{
return &buf[1];
}
//第二种方式,利用typedef定义一个数组指针类型,作为函数的返回值类型
typedef char (*R)[4][2];
R fun1()
{
return &buf[1];
}
//第三种方式,直接定义。
char (*fun2())[4][2]
{
return &buf[1];
}
/*函数参数为数组的测试*/
//char (*buf)[4]是一个指针,它的类型char (*)[4]
void fun3(char (*buf)[4])
{
buf++;
printf("%d:size(buf):%d\n", __LINE__, (int)(buf+1) - (int)buf);
}
// char buf[4]是定义一个指针buf,类型就是char *,(4这里没意义)
void fun4(char buf[4])
{
char a[2][4];
buf++;
//a = &buf; //buf因为是char *,取地址后为char **,不匹配报错
printf("%d:size(buf):%d\n", __LINE__, (int)(buf+1) - (int)buf);
}
// char buf[4]是定义一个指针buf,类型就是char *
void fun5(char buf[])
{
char a[2][4];
//a = &buf; //buf因为是char *,取地址后为char **,不匹配报错
buf++;
printf("%d:size(buf):%d\n", __LINE__, (int)(buf+1) - (int)buf);
}
//定义指针buf,类型char (*)[][4]. 4在这里有意义
void fun6(char buf[2][4])
{
printf("%d:buf[0][0]=%d\n", __LINE__, buf[0][0]);
buf[0][0] = 5;
printf("%d:buf[0][0]=%d\n",__LINE__, buf[0][0]);
printf("%d:size(buf):%d\n", __LINE__, (int)(buf+1) - (int)buf);
}
//定义指针buf,类型char (*)[][4]. 4在这里有意义
void fun7(char buf[][4])
{
printf("%d:buf[0][0]=%d\n", __LINE__, buf[0][0]);
buf[0][0] = 5;
printf("%d:buf[0][0]=%d\n",__LINE__, buf[0][0]);
printf("%d:size(buf):%d\n", __LINE__, (int)(buf+1) - (int)buf);
}
//定义指针buf,类型char (*)[2][4]. 2和4在这里有意义
void fun8(char (*buf)[2][4])
{
buf++;
printf("%d:size(buf):%d\n", __LINE__, (int)(buf+1) - (int)buf);
}
int main(int argc, char *argv[])
{
char (*p)[4][2];
printf("%d:size(p):%d\n", __LINE__, (int)(p+1) - (int)p);
printf("%d: %d,%d\n", __LINE__, buf[1][0][0], buf[1][0][1]);
p = &buf[1];
printf("%d: %d,%d\n", __LINE__, (*p)[0][0],(*p)[0][1]);
p = fun();
p = fun1();
p = fun2();
char *p0;
char buf0[2] = {1};
p0 = buf0;
char (*p1)[4];
char buf1[2][4] = {1};
p1 = buf1;
printf("%d:size(p1):%d\n", __LINE__,(int)(p1+1) - (int)p1);
printf("%d:size(buf1):%d\n", __LINE__, (int)(buf1+1) - (int)buf1);
char (*p2)[2][4];
char buf2[2][2][4] = {1};
p2 = buf2;
p2 = &buf2[1];
printf("%d:size(p2):%d\n", __LINE__, (int)(p2+1) - (int)p2);
printf("%d:size(buf2):%d\n",__LINE__, (int)(buf2+1) - (int)buf2);
printf("%d:size(buf2[1]):%d\n", __LINE__, (int)(buf2[1]+1) - (int)buf2[1]);
char buf3[2][4] = {3};
fun3(buf3);
fun4(buf3[0]);
fun5(buf3[0]);
fun6(buf3);
fun7(buf3);
fun8(&buf3);
return 0;
}
运行结果:
gjt@ubuntu:~/test$ ./a.out
72:size(p):8
73: 11,12
75: 11,12
87:size(p1):4
88:size(buf1):4
94:size(p2):8
95:size(buf2):8
96:size(buf2[1]):4
32:size(buf):4
39:size(buf):1
46:size(buf):1
51:buf[0][0]=3
53:buf[0][0]=5
54:size(buf):4
58:buf[0][0]=5
60:buf[0][0]=5
61:size(buf):4
66:size(buf):8
gjt@ubuntu:~/test$