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

原创 2015年07月10日 11:05:15

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

例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$
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

C++ 中复合类型声明的理解(尤其是指针数组/数组指针/多维数组的问题)

这几天看《C++ Primer》第五版感觉还是颇有收获的,澄清了之前很多不是很理解的概念,也知道了好多新用法 首先,先澄清一个误解,就是数组的定义问题,在C中C99标准之后数组定义时...

多维数组与指针

  • 2013-09-16 09:00
  • 3.13MB
  • 下载

多维数组和指针

一维数组名即是一个指针常量,它代表数组第一个元素的地址,知道一维数组的长度,那么可以通过数组名输出一维数组的所有元素: #include stdio.h> int main...

C语言多维数组与多级指针

多维数组与多级指针也是初学者感觉迷糊的一个地方。超过二维的数组和超过二级的指针其实并不多用。如果能弄明白二维数组与二级指针,那二维以上的也不是什么问题了。所以本节重点讨论二维数组与二级指针。 一、二...

C语言入门之多维数组的指针变量

C语言入门之多维数组的指针变量 一、多维数组地址的表示方法    设有整型二维数组a[3][4]如下:    0 1 2 3    4 5 6 7    8 9 10 1...

c指向多维数组的指针

1、实际上并不存在多维数组,所谓的多维数组本质上是用一维数组模拟的。 2、数组名是一个常量(意味着不允许对其进行赋值操作),其代表数组首元素的首地址。 3、数组与指针的关系是因为数组下标操作符[]...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)