typedef char Line[81]
Line text;
char text[81]
111111111111111111111111111111111111111111111111111
typedef char TA[5];//定义数组类型
typedef char *TB[5];//定义指针数组类型,PA定义的变量为含5个char*指针元素的数组(指针数组类型)
typedef char *(TC[5]);//指针数组类型,因为[]的结合优先级最高,所以加不加()没啥区别,TC等价于TB
typedef char (*TD)[5];//数组指针类型
22222222222222222222222222222222222222222222222222222
指针数组(Pointer Array)和数组指针(Array Pointer)是两种不同类型的概念,它们在定义和使用上有所区别。
指针数组:指针数组是一个数组,其中的每个元素都是指针类型。也就是说,指针数组存储了多个指针的地址,这些指针可以指向不同类型的数据或对象。指针数组的声明方式为:type *array[],其中type为指针指向的数据类型。例如,int *ptrArray[5]表示一个包含5个指向整数类型数据的指针的数组。
在指针数组中,每个元素都可以单独指向不同的内存空间,可以用于存储不同类型或者不同位置的数据,因此具有更大的灵活性。
+++++++++++++++++++++++++++++++++++++++++++++++++++
数组指针:数组指针是一个指针,它指向一个数组的首地址。数组指针的声明方式为:type (*ptr)[size],其中type为数组中元素的数据类型,size为数组的大小。例如,int (*ptr)[5]表示一个指向包含5个整数类型元素的数组的指针。
数组指针解析出来的是整个数组,因此可以通过指针进行遍历访问数组的所有元素。数组指针通常用于处理多维数组。
总的来说,指针数组是一个数组,每个元素都是指针类型,而数组指针是一个指针,指向一个数组。指针数组提供了灵活性,可以存储不同类型或位置的数据,而数组指针则用于处理整个数组,可以遍历访问数组的所有元素。
3333333333333333333333333333333333333333333333333333333333
定义函数指针类型
我们首先来看一下如何定义函数指针变量,然后再看如何定义函数指针类型
1、定义函数指针变量
① int (*pFunc)(char *frame, int len);
定义了一个函数指针变量pFunc,它可以指向这样的函数:返回值为int,形参为char*、int
② int *(*pFunc[5])(int len);
定义了5个函数指针变量:pFunc[0]、pFunc[1]···,它们都可以指向这样的函数:返回值为int*,形参为int
2、定义函数指针类型
定义函数指针类型,必须使用typedef,方法就是,在“定义函数指针变量”加上typedef。
typedef int (*pFunc_t)(char *frame, int len);//定义了一个类型pFunc_t
举例:
typedef int (*pFunc_t)(char *frame, int len);//定义了一个类型pFunc_t
int read_voltage(char *data, int len)
{
int voltage = 0;
···//其他功能代码
return voltage;
}
int main(void)
{
pFunc_t pHandler = read_voltage;//使用类型pFunc_t来定义函数指针变量
···//其他功能代码
}
4444444444444444444444444444444444444444444444444444444444444444444444
二维数组名、二维数组名取地址、二级指针
首先给出几个定义:
typedef int (*p1x4)[4];//定义数据类型,p1x4这种类型为指向含4个int元素的1维数组的指针
typedef int (*p3x4)[3][4];//定义数据类型,p3x4这种类型为指向含3x4个int元素的2维数组的指针
下面从一维数组说起:(定义:int a[4])
(1)一维数组名a是个地址,地址类型为:int *
(2)一维数组名取地址&a是个地址,地址类型同:int (*p)[4], 也即&a指向含4个int元素的一维数组
备注:a和&a,两者都是个地址,且这两个地址的数值完全相等。
再看二维数组b[3][4],这个二维数组也可以可以看成一个含3个成员的一维数组,每一个成员含有4个int元素,依次,仿照一维数组的结论,有:
(1)b[0]是个一维数组名,也是个地址,地址类型为:int *
(2)&b[0]是个地址,地址类型同:int (*p)[4], 也即&b[0]指向含4个int元素的一维数组
更进一步:
(3)b是个地址,地址类型同:int (*p)[4],也即b指向含4个int元素的一维数组
(4)&b是个地址,地址类型同:int (*p)[3][4],也即&b指向含3x4个int元素的2维数组
注意:尤其注意上面的(3),这条结论指出了:二维数组名实际上是一维数组的地址!
总结:
① 数组名,是指向它的第一个一级成员的指针
② 数组名取地址,是指向整个数组的指针
PS:所谓一级成员,举个例子,int a[5],那么数组a的一级成员就是int型变量;int b[10][5],数组b的一级成员是int [5]的一维数组
555555555555555555555555555555555555555555555555555555555555555
指针数组和数组指针的概念
指针数组: 指针数组可以说成是”指针的数组”,首先这个变量是一个数组,其次,”指针”修饰这个数组,意思是说这个数组的所有元素都是指针类型,在32位系统中,指针占四个字节。
数组指针: 数组指针可以说成是”数组的指针”,首先这个变量是一个指针,其次,”数组”修饰这个指针,意思是说这个指针存放着一个数组的首地址,或者说这个指针指向一个数组的首地址。
————————————————
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/qq_43522889/article/details/126788911