指针和数组的对比:
指针数组和数组指针:
要理解这几个概念,就要明白:好孩子,首先他是个孩子。
指针数组:
就是指针的数组,也就是说它实质上是一个数组,只是数组的每个元素都是指针,至于数组占多少个字节由数组本身决定。它是存储指针的数组的简称。例如:
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)() , 函数调用
从上面的介绍中我们可以大致了解到指针与数组,指针数组,数组指针以及函数指针的有关知识,相信很多小伙伴可能在初次接触这些问题时感觉到很懵,但是不论遇到什么样的问题,只要我们耐下性子,一步步的分析,逐渐解决问题,我们将会收获不一样。
对于学有余力的同学,我们可以接着学习函数指针数组,函数指针数组的指针,好像听起来很绕口,晦涩难懂,可是本源皆是相同,不信?那你点开看看:点击打开链接