【C语言】数组指针-c语言的任督二脉

视频链接:bilibili

关于指针需要注意的地方

只有以下两种情况数组名表示的是整个数组
1.sizeof(数组名)
2.&数组名
除此之外数组名表示的都是首元素地址

一、字符指针

是一个指向字符的指针

int main()
{
	char ch = 'w';
	char* p = &ch;
	//char* ch2 = "abcdef";//ch2里放的是字符串a的地址
	const char* ch2 = "abcdef";//常量字符串不允许被修改,int前面加const,修饰的是*ch2
	//char* const ch2 = "abcdef";//const修饰的是ch2这个地址
	return 0;
}

二、指针数组

是一个数组,是用来存放指针的数组

int main()
{
	int arr1[] = { 1,2,3,4,5,6 };
	int arr2[] = {2,3,4,5,6,7};
	int arr3[] = {3,4,5,6,7,8};
	int* parr[] = { arr1,arr2,arr3 };
	int i = 0;
	for (i = 0; i < 3; i++)
	{
		int j = 0;
		for (j = 0; j < 5; j++)
		{
			printf("%d ", *(parr[i] + j));
		}
		printf("\n");
	}
	return 0;
}

三、数组指针

数组指针是一个指针,用来存放数组的指针

int *p1[10];//p1指的是一个存放指针的数组,这个数组中存储的是10个int类型的指针
int (*p2)[10];//p2指的是一个指针,指针指向数组,数组中有10个元素,括号优先级高于[]
int main()
{
	char* arr[5];
	char* (* pa)[5] = &arr;
	return 0;
}

在这里插入图片描述

void print1(int (*p)[5],int x, int y )
{
	int i = 0;
	for(i=0;i<3;i++)
	{
		int j = 0;
		for(j=0;j<5;j++)
		{
			//体会下面解引用的不同方法
			printf("%d ", *(*(p+i)+j));
			printf("%d ", *(p[i]+j));
			printf("%d ", *(p+i)[j]);
			printf("%d ", p[i][j]);
		}
		printf("\n");
	}
}
int main()
{
	int arr[3][5] = {{1,2,3,4,5},{2,3,4,5,6},{3,4,5,6,7}};
	print1(arr, 3, 5);//arr--数组名--数组名就是首元素地址
	return 0;
}

思考下面代码表示是什么意思

int arr[5];
int *parr1[10];
int (*parr2)[10];
int (*parr3[10])[5];

四、数组传参

一维数组传参

void test(int arr)//不行
void test(int arr[5])//可以
void test(int arr[])//可以
void test(int* arr[])//可以
void test1(int* arr[])//可以
void test1(int* arr[5])//可以,arr2是一个指针数组,既然是数组就可以用指针接收
void test1(int** arr)//可以,arr2内存储是指针,那么可以用二级指针接收

int main()
{
	int arr[5] = { 0 };
	int* arr2[5] = { 0 };//指针数组,数组的每个元素是指针,arr2表示的是首元素地址,
	//可以用首元素地址的地址来接收
	test(arr);
	test1(arr2);
	return 0;
}

二维数组传参
二维数组传参时,行可以省略,列不可省略

void test(int arr[3][5])//可以
void test(int *arr)//不行
void test(int *arr[5])//不行
void test(int (* arr)[5])//可以
void test(int **arr)//不行

int main()
{
	int arr[3][5] = { 0 };
	test(arr);
	return 0;
}

五、函数指针

指向函数的指针, 需要明确函数也有地址
&函数名和函数名都是函数的地址。而函数指针在调用的时候可以使用解引用也可以不解引用

int Add(int x, int y)
{
	int z = x + y;
	return z;
}
int main()
{
	int a = 10;
	int b = 20;
	//printf("%d\n", Add(a, b));
	//printf("%p\n", &Add);
	int (*pa)(int, int) = Add;//将函数Add的地址存到pa这个函数指针中。
	printf("%d\n", (*pa)(2,3));
	return 0;
}
**思考下面代码的含义**
(*(void (*)())0)();

六、函数指针数组

函数指针数组,是一个数组,存放的是函数的地址

int Add(int x, int y)
{
	return x + y;
}
int Sub(int x, int y)
{
	return x - y;
}
int main()
{
	//int (*pa)(int, int) = Add;
	int (*pa[2])(int, int) = {Add, Sub};
	int i = 0;
	for (i = 0; i < 2; i++)
	{
		printf("%d\n", pa[i](2, 3));//5  -1  函数指针在调用的时候可以使用解引用也可以不解引用
	}
	return 0;
}

函数指针数组—也可以称为转移表

//实现一个计算器的功能
int Add(int x, int y)
{
	return x + y;
}
int Sub(int x, int y)
{
	return x - y;
}int Mul(int x, int y)
{
	return x * y;
}int Div(int x, int y)
{
	return x / y;
}
void menu()
{
	printf("----------------------------------\n");
	printf("---------1.Add   2.Sub -----------\n");
	printf("---------3.Mul   4.Div -----------\n");
	printf("--------     0.exit   ------------\n");
	printf("----------------------------------\n");
}
int main()
{
	int input = 0;
	int a = 0;
	int b = 0;
	do
	{
		menu();
		printf("请选择:>");
		scanf_s("%d", &input);
		printf("请输入两个操作数:>");
		scanf_s("%d%d", &a, &b);
		//paArr是一个函数指针数组--转移表
		int (*paArr[])(int, int) = {0, Add, Sub, Mul, Div};
		if (input>=1 && input<=5)
		{
			int ret = paArr[input](a,b);
			printf("%d\n", ret);
		}
		else if (input == 0)
		{
			printf("退出");
			break;
		}
		else
		{
			printf("输出错误");
		}
	} while (input);
	return 0;
}

七、指向[函数指针数组]的指针

int main()
{
	int arr[5] = { 0 };
	//pf是一个函数指针
	int (*pf)(int,int);
	int(*pf)[5] = &arr;//p是一个数组指针
	//pfArr是一个数组
	//是一个函数指针数组,包含5个元素
	//每个元素的类型是一个函数指针
	//函数指针的类型是int (*)(int,int)
	int (*pfArr[5])(int,int);
	//ppfArr是一个指针
	//是一个数组指针,指向的数组有5个元素
	//每个元素的类型是一个函数指针
	//函数指针的类型是int (*)(int,int)
	int (*(*ppfArr)[5])(int, int) = &pfArr;//ppfArr是一个指向[函数指针数组]的指针
	return 0;
}

八、回调函数

通过函数指针调用的函数,用于解决代码冗余的问题,如果把函数的地址作为参数传递给另一个函数,

#include <stdio.h>
//设计一个main函数,用于调用一个回调函数
//设计一个print函数,实现打印字符串的功能
//设计一个回调函数,用于接收函数地址,
//并且在回调函数内部调用print函数
void print(char *str)//print函数是打印字符串的
{
	printf("%s\n", str);
}

void test(void (*p)(char*))//test函数是一个回调函数
{

	printf("haha\n");
	p("bit");//调用test接收到的函数指针,找到对应的函数进行调用
}

int main()
{
	test(print);
	return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/7499.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Netty组件Future、Promise、Handler、Pipline、ByteBuf

Future&Promise Netty中的Future与jdk中的Future同名&#xff0c;但是是两个接口&#xff0c;netty的Future继承自jdk的Future,而Promise又对netty Future进行了扩展 jdk Future只能同步等待任务结束(或成功、或失败)才能得到结果netty Future可以同步等待任务结束得到结…

阿里云弹性计算高级产品专家马小婷:ECS 使用成熟度评估与洞察

2023 年 3 月 22 日&#xff0c;【全新升级 阿里云 ECS CloudOps 2.0 来啦】发布会正式播出&#xff0c;本次发布会上阿里云宣布 CloudOps&#xff08;云上自动化运维&#xff09;套件全新升级&#xff0c;并发布了 CloudOps 云上自动化运维白皮书 2.0 版本。阿里云弹性计算高级…

【数据结构】栈和队列(笔记总结)

&#x1f466;个人主页&#xff1a;Weraphael ✍&#x1f3fb;作者简介&#xff1a;目前学习C和算法 ✈️专栏&#xff1a;数据结构 &#x1f40b; 希望大家多多支持&#xff0c;咱一起进步&#xff01;&#x1f601; 如果文章对你有帮助的话 欢迎 评论&#x1f4ac; 点赞&…

DC-1渗透实战

目标机&#xff1a;192.168.26.161 攻击机&#xff1a;192.168.26.144 1、信息收集&#xff1a; 使用ARP扫描&#xff0c;获得信息&#xff1a; arp-scan -l 适应NMAP进行扫描IP为192.168.26.161 &#xff0c;看他开启了哪些端口、服务和操作系统&#xff1a; nmap -A -T…

SQL函数

文章目录一、SQL 函数二、SQL COUNT() 函数三、SQL FIRST() 函数四、SQL LAST() 函数五、SQL MAX() 函数总结一、SQL 函数 SQL 拥有很多可用于计数和计算的内建函数。 SQL Aggregate 函数 SQL Aggregate 函数计算从列中取得的值&#xff0c;返回一个单一的值。 有用的 Aggrega…

「程序员值得一看」| 传说中的“全球公认最健康的作息时间表”

身体是革命的本钱&#xff0c;健康问题关乎我们每一个人&#xff0c;说到健康作息&#xff0c;下面这篇文章还是非常值得我们参考的&#xff0c;当然每个人结合自身可以好好总结一下。 都说程序员这一行&#xff0c;猝死概率极高&#xff0c;究其原因还是很难有很好的作息规律…

【Matlab算法】粒子群算法求解二维线性优化问题(附MATLAB代码)

MATLAB求解二维线性优化问题前言正文函数实现可视化结果前言 二维线性优化问题指的是在二维空间中&#xff0c;对于一个由线性函数构成的目标函数&#xff0c;通过限制自变量的范围或满足特定的约束条件&#xff0c;寻找一个最优解&#xff08;最小值或最大值&#xff09;。这…

面试官 : 你了解的MySQL 集群高可用架构都有哪些?

文章目录 MySQL 主从架构MySQL+DRDB 架构MySQL+MHA 架构MySQL+MMM 架构MySQL 主从架构 此种架构,一般初创企业比较常用,也便于后面步步的扩展 此架构特点: 1、成本低,布署快速、方便 2、读写分离 3、还能通过及时增加从库来减少读库压力 4、主库单点故障 5、数据一致性问题…

Windows上提示 api-ms-win-core-path-l1-1-0.dll 丢失怎么办?

Windows上提示 api-ms-win-core-path-l1-1-0.dll 丢失怎么办&#xff1f;最近有用户在开启电脑的photoshop软件使用的时候&#xff0c;出现另外无法启动软件的情况&#xff0c;因为系统中缺失了对应的dll文件。那么这个情况怎么去进行问题的解决呢&#xff1f;来看看以下的解决…

PyTorch深度学习实战 | 基于YOLO V3的安全帽佩戴检测

本期将提供一个利用深度学习检测是否佩戴安全帽的案例,从而展示计算机视觉中的目标识别问题的一般流程。目标检测是基于图片分类的计算机视觉任务,既包含了分类,又包含了定位。给出一张图片,目标检测系统要能够识别出图片的目标并给出其位置。由于图片中目标数是不确定的,…

JUC并发编程第一章之进程/并发/异步的概念[理解基本概念]

1. 进程和线程的概念 进程: 系统正在运行的一个应用程序;程序一旦运行就是一个进程;进程是资源分配的最小单位 线程: 是进程的实际运行单位;一个人进程可以并发控制多个线程,每条线程并行执行不同的任务 区别: 进程基本上相互独立的;而线程存在于进程内&#xff0c;是进程…

类ChatGPT项目的部署与微调(上):从LLaMA到Alpaca、Vicuna、BELLE

前言 近期&#xff0c;除了研究ChatGPT背后的各种技术细节 不断看论文(至少100篇&#xff0c;100篇目录见此&#xff1a;ChatGPT相关技术必读论文100篇)&#xff0c;还开始研究一系列开源模型(包括各自对应的模型架构、训练方法、训练数据、本地私有化部署、硬件配置要求、微…

如何把多个文件(夹)随机复制到多个文件夹中

首先&#xff0c;需要用到的这个工具&#xff1a; 百度 密码&#xff1a;qwu2 蓝奏云 密码&#xff1a;2r1z 先看文件的情况一共20个兔兔的图片&#xff0c;4个文件夹&#xff0c;把全部的图片随机的复制这些地方去 打开工具&#xff0c;切换到 文件批量复制 版块 找到右下角…

Java EE企业级应用开发(SSM)第3章

第3章Spring Bean装配一.预习笔记 1.Spring中的Bean 在Spring中&#xff0c;一切Java类都被视为资源&#xff0c;而这些资源都被视为Bean&#xff0c;而Spring就是管理这些Bean的容器。 Bean的配置有3种方式&#xff0c;分别是XML文件配置、Java类和注解 2.基于XML的Bean装…

`Caché/IRIS` 代码优化效率提升十一条 - 持续更新

文章目录Cach/IRIS代码优化效率提升十一条 - 持续更新 汇总数据使用多维数组Global取数据时需将Global先赋值变量将表达式直接返回使用块语法的运行效率要比点语法更快复杂的if逻辑条件&#xff0c;可以调整顺序&#xff0c;让程序更高效在循环中取不变的配置时&#xff0c;应使…

SpringRetry接口异常优雅重试机制

场景&#xff1a; 某些场景下&#xff0c;如果接口出现异常需要进行重试&#xff0c;例如网络抖动、调用接口超时等并非接口代码导致的报错&#xff0c;此时可以进行接口重试机制 1、导入 spring retry 重试依赖 <!-- spring retry --><dependency><groupId>…

【Node.js】Express框架的基本使用

✍️ 作者简介: 前端新手学习中。 &#x1f482; 作者主页: 作者主页查看更多前端教学 &#x1f393; 专栏分享&#xff1a;css重难点教学 Node.js教学 从头开始学习 目录 初识Express Express简介 什么是Express 进一步理解 Express Express能做什么 Express的基本使用 …

分享:如何给 DBA 减负?

欢迎访问 OceanBase 官网获取更多信息&#xff1a;https://www.oceanbase.com/ 本文来自OceanBase社区分享&#xff0c;仅限交流探讨。原作者肖杨&#xff0c;OceanBase 软件开发工程师。 研发、数据分析师及运维内部人员有数据查询、数据订正等需求&#xff0c;若无管控平台&…

Midjourney 使用总结

1.关键词提问 中国古典女性&#xff0c;东方美女极致面容站在运河码头遥望丈夫&#xff0c;史诗奇幻场景风格&#xff0c;深绿浅棕&#xff0c;细节风帆&#xff0c;柔焦&#xff0c;人像隐喻&#xff0c;4K&#xff0c;电影级高品质照片&#xff0c;全景图&#xff0c; 焦距 …

突破市场壁垒:如何利用关键词采集和市场调查找到你的细分市场?

在市场竞争日益激烈的今天&#xff0c;寻找一个适合自己的细分市场成为了每个企业和创业者的必要之举。然而&#xff0c;许多人在寻找细分市场时陷入了困境&#xff0c;不知道如何找到一个符合自己产品的市场&#xff0c;因此&#xff0c;在这种情况下&#xff0c;利用关键词采…