文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C语言的数组指针与函数指针详解

2024-04-02 19:55

关注

前言

数组指针和函数指针都是C语言比较难的知识点,尤其是函数指针,并且函数指针在开发中有着巨大的作用。

函数指针语法

定义一个函数指针,并通过函数指针间接调用函数:

int get_num(int a, int b)
{
    return a + b;
}
int (*func)(int a, int b); //定义了一个函数指针func,它指向 返回值为int 参数为 int a, int b的函数
func = &get_num; //函数指针指向函数
func(1, 2); //通过函数指针调用函数

通过定义一个函数指针类型来定义一个函数指针:

typedef int (*func)(int a, int b); //定义了一个函数指针类型
func func1 = &get_num; //使用函数指针类型func定义函数指针变量func1

定义一个函数类型,并使用函数类型来定义一个函数指针

typedef int (func)(int a, int b); //定义了一个函数类型
func* func1 = &get_num;
func1(1, 1); //间接调用

函数指针约定了函数的返回值和函数参数,功能开发者只要根据这个约定实现功能函数,就可以通过以函数指针为参数的统一接口进行调用,来使用这个函数的功能,实现了功能开发与功能使用的解耦合。这就是函数指针的巨大作用:函数指针做函数参数

另外函数指针的正向调用使用场景,比如通过把动态库加载到程序中,在动态库中查找到函数入口地址来调用函数。

数组指针与指针数组

数组指针是指向数组的指针;指针数组是指针的数组。

数组指针举例

#define  _CRT_SECURE_NO_WARNINGS 
#include <stdlib.h>
#include <string.h>
#include <stdio.h>
void PrintArray_int(int* array, int len)
{
	if ((NULL == array) || (len < 0))
	{
		printf("err:(NULL == array) || (len < 0)\n");
		return;
	}
	for (int i = 0; i < len; i++)
	{
		//两种方法访问数组元素
		//printf(" %d ", array[i]);
		printf(" %d ", *(array + i));
	}
	printf("\n");
}
int main()
{
	//定义一个数组变量
	int num_array[10];
	// num_array + 1 移动 sizeof(int) 个字节
	int len = sizeof(num_array) / sizeof(num_array[0]);
	//memset(num_array, 0, sizeof(num_array) / sizeof(num_array[0])); //典型错误,只把十个字节的内存值为0
	memset(num_array, 0, sizeof(num_array)); //实际应该把40个字节置为0
	PrintArray_int(num_array, sizeof(num_array) / sizeof(num_array[0]));
	//定义一个数组类型
	typedef int(array1_t)[];
	typedef int(array2_t)[10];
	array1_t a1 = {1, 2, 3};
	array2_t a2;
	for (int i = 0; i < 10; i++)
	{
		a2[i] = i;
	}
	PrintArray_int(a1, sizeof(a1) / sizeof(a1[0]));
	PrintArray_int(a2, 10);
	//定义一个数组指针
	int(*p_array)[10];
	// p_array + 1 移动 sizeof(int) * 10 个字节
	p_array = &num_array;
	for (int i = 0; i < 10; i++)
	{
		(*p_array)[i] = i + 1;
	}
	PrintArray_int(*p_array, 10);
	//定义一个指向数组的指针类型(数组指针)
	typedef int(*p_array_t)[10];
	p_array_t p1 = &num_array;
	for (int i = 0; i < 10; i++)
	{
		(*p1)[i] = i + 2; //先解引用,还原为一级指针(数组本身可以看为一级指针
						  //数组指针是指向数组的指针,也就是指向一级指针的指针,即二级指针)
	}
	PrintArray_int((*p1), 10);
	//指针数组
	const char* p2[2] = { "aaa", "bbb" };
	//p2[0] 和 p2[1] 都是一个指针
	printf("%s\n", p2[0]);
	printf("%s\n", p2[1]);
	system("pause");
	return 0;
}

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程网的更多内容!   

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯