数组 指针 函数

2024-06-22 04:52
文章标签 指针 数组 函数

本文主要是介绍数组 指针 函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

这篇关于数组 指针 函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1083340

相关文章

【操作系统】信号Signal超详解|捕捉函数

🔥博客主页: 我要成为C++领域大神🎥系列专栏:【C++核心编程】 【计算机网络】 【Linux编程】 【操作系统】 ❤️感谢大家点赞👍收藏⭐评论✍️ 本博客致力于知识分享,与更多的人进行学习交流 ​ 如何触发信号 信号是Linux下的经典技术,一般操作系统利用信号杀死违规进程,典型进程干预手段,信号除了杀死进程外也可以挂起进程 kill -l 查看系统支持的信号

java中查看函数运行时间和cpu运行时间

android开发调查性能问题中有一个现象,函数的运行时间远低于cpu执行时间,因为函数运行期间线程可能包含等待操作。native层可以查看实际的cpu执行时间和函数执行时间。在java中如何实现? 借助AI得到了答案 import java.lang.management.ManagementFactory;import java.lang.management.Threa

SQL Server中,isnull()函数以及null的用法

SQL Serve中的isnull()函数:          isnull(value1,value2)         1、value1与value2的数据类型必须一致。         2、如果value1的值不为null,结果返回value1。         3、如果value1为null,结果返回vaule2的值。vaule2是你设定的值。        如

tf.split()函数解析

API原型(TensorFlow 1.8.0): tf.split(     value,     num_or_size_splits,     axis=0,     num=None,     name='split' ) 这个函数是用来切割张量的。输入切割的张量和参数,返回切割的结果。  value传入的就是需要切割的张量。  这个函数有两种切割的方式: 以三个维度的张量为例,比如说一

C语言入门系列:探秘二级指针与多级指针的奇妙世界

文章目录 一,指针的回忆杀1,指针的概念2,指针的声明和赋值3,指针的使用3.1 直接给指针变量赋值3.2 通过*运算符读写指针指向的内存3.2.1 读3.2.2 写 二,二级指针详解1,定义2,示例说明3,二级指针与一级指针、普通变量的关系3.1,与一级指针的关系3.2,与普通变量的关系,示例说明 4,二级指针的常见用途5,二级指针扩展到多级指针 小结 C语言的学习之旅中,二级

剑指offer(C++)--数组中只出现一次的数字

题目 一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。 class Solution {public:void FindNumsAppearOnce(vector<int> data,int* num1,int *num2) {int len = data.size();if(len<2)return;int one = 0;for(int i

利用结构体作为函数参数时结构体指针的定义

在利用结构体作为函数的参数进行传递时,容易犯的一个错误是将一个野指针传给函数导致错误。 #include <stdio.h>#include <math.h>#include <malloc.h>#define MAXSIZE 10typedef struct {int r[MAXSIZE]; //用于存储要排序的数组,r[0]作为哨兵或者临时变量int length;

神经网络第三篇:输出层及softmax函数

在上一篇专题中,我们以三层神经网络的实现为例,介绍了如何利用Python和Numpy编程实现神经网络的计算。其中,中间(隐藏)层和输出层的激活函数分别选择了 sigmoid函数和恒等函数。此刻,我们心中不难发问:为什么要花一个专题来介绍输出层及其激活函数?它和中间层又有什么区别?softmax函数何来何去?下面我们带着这些疑问进入本专题的知识点: 1 输出层概述 2 回归问题及恒等函数 3

神经网络第一篇:激活函数是连接感知机和神经网络的桥梁

前面发布的文章介绍了感知机,了解了感知机可以通过叠加层表示复杂的函数。遗憾的是,设定合适的、能符合预期的输入与输出的权重,是由人工进行的。从本章开始,将进入神经网络的学习,首先介绍激活函数,因为它是连接感知机和神经网络的桥梁。如果读者认知阅读了本专题知识,相信你必有收获。 感知机数学表达式的简化 前面我们介绍了用感知机接收两个输入信号的数学表示如下:

IOS 数组去重的几种方式

本来只知道NSSet和KeyValues的。今天又新学了几种方式 还有就是和同事学的一种方式 外层循环从0开始遍历,内层从最后一个元素开始遍历 for(int i=0;i<index;i++){  for(int j=index-1;j>i;j-- ){ } }