详解指针数组,数组指针,函数指针

指针和数组的对比:

指针数组和数组指针:

要理解这几个概念,就要明白:好孩子,首先他是个孩子。

指针数组:

就是指针的数组,也就是说它实质上是一个数组,只是数组的每个元素都是指针,至于数组占多少个字节由数组本身决定。它是存储指针的数组的简称。例如:

int *p1[10];//指针数组

解释上面代码:由于"[]"优先级要比''*''的优先级高,所以p1先和“[]"结合,构成数组的定义,数组名为p1,int*修饰的是数组的内容,即数组的每个元素是整型指针类型。也就是说,这是一个数组,其包含10个指向int类型数据的指针,即指针数组;


数组指针:

就是数组的指针,就是说它实质上是一个指针,它指向一个数组,在32位操作系统下永远占4个字节,至于它指向的数组占多少个字节,不清楚。他是指向数组的指针的简称。例如:

int (*p2)[10]//数组指针

根据优先级,"*"和"p2"构成一个指针的定义,指针变量名为p2,int修饰的是数组的内容,即数组的每一个元素都是整型类型。也就是说,这是一个指针,它指向包含10个int类型的数据的数组,即数组指针。


函数指针:

类比前面的说法,函数指针就是函数的指针,它是一个指针,指向一个函数,例如:

char *(*fun1)(char *p1,char *p2);//函数指针

代码解释:fun1是一个指针变量,指向一个函数,这个函数由两个参数p1和p2,其类型为指针,函数的返回值也是一个指针。

看一个比较复杂的例子:

void function()
{
	printf("Call function!\n");
}
int main()
{
	void(*p)();//定义了一个指针变量p,p指向一个函数,这个函数的参数和返回值都是void
	*(int*)&p = (int)function;
	//&p表示求指针变量p本身的地址,
	//(int*)&p表示将地址强制转换成int类型数据的指针,
	//(int)function表示将函数的入口地址强制转换成int类型的数据,
	//那么,*(int*)&p = (int)function;表示将函数的入口地址赋值给指针变量p
	(*p)();//表示对函数的调用
	return 0;
}

再来一个:

(*(void(*)())0)();

看了这个代码,有没有一种mmp的感觉,我刚开始看这个代码的时候,让我想到了《c语言

从入门到放弃》这本书,哈哈,好了,不用担心,让我们跟随大神的脚步,慢慢分析,

(1)void(*)(),这是什么?这是一个函数指针类型,参数和返回值都是void

(2)void(*)()0, 将0强制转换成一个函数指针类型,表示0是一个地址了。

(3)(*(void(*)())0),取0地址开始的一段内存中的内容,其内容就是保存在首地址为0的一段区域内的函数

(4)(*(void(*)())0)() ,  函数调用

从上面的介绍中我们可以大致了解到指针与数组,指针数组,数组指针以及函数指针的有关知识,相信很多小伙伴可能在初次接触这些问题时感觉到很懵,但是不论遇到什么样的问题,只要我们耐下性子,一步步的分析,逐渐解决问题,我们将会收获不一样。

对于学有余力的同学,我们可以接着学习函数指针数组,函数指针数组的指针,好像听起来很绕口,晦涩难懂,可是本源皆是相同,不信?那你点开看看:点击打开链接






猜你喜欢

转载自blog.csdn.net/weixin_40123831/article/details/80153919