在C语言中,很多开发人员都会害怕指针这个东西,但是真正懂它的就觉得很简单了,你想把它弄懂,其实不难,请往下看。函数的名字其实就是该函数的地址,换句话说,函数名本身就是一个指向其代码区域的指针,因此取函数地址时,取址符是可选的。
拓展:
函数指针在C语言里是特别重要的概念,因为很多关键技术最终都会落实到函数指针上。所谓函数指针,就是“指向函数的指针”,假如有这么一个函数:
char * function (int a, float f);那么指向该函数的指针,应该定义为:
char * (*p2func)(int a, float f);然后,将该指针指向这个函数:
p2func = &function;
这样,指针p2func就保存了函数function的地址了,以后可以使用p2func来调用函数:
(*p2func)(100, 3.14);
从这个样例中看到,对函数取址、赋值、对函数指针调用等,跟普通的指针和变量没啥区别。
另外,由于函数名字本身就是地址,也就是说function本身就是代表了该函数的地址,因此上述指针赋值和解引用又可以写为:
p2func = function; (省略了取址符&)
p2func(100, 3.14); (省略了解引用符*)
看到这里,是不是觉得清晰了很多,是不是觉得它实际没那么难,还是挺可爱的,你对它温柔,它也不会亏待你的,可以手动去敲一敲,练拳也要练功,这样会记得更牢固。