多维数组的指针类型转换和参数传递

总结:
一维和多维数组的数组名,是一个指针,这个指针指向的是该数组的第一个“元素”。

例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].  24在这里有意义
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$
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值