#include #include /* * 返回指针的函数和指向函数的指针 */ /* * 定义一个函数,返回一个void指针,在C语言中,void指针可以 * 指向任何类型 */ void *func(){ /* * 一种很容易犯的错误,将局部变量的地址返回 */ int m; printf("define as void *func()\n"); return &m; } /* * 声明一个指向函数的指针,指向返回类型为void指针的函数 */ void *(*pfunc)(); /* void (*pfun)(); * 声明一个函数,指向一个返回void的函数。其实这个和第一种 * void *func()是大多数人最容易混淆的方式。总结中会介绍 * 分辨的方法。因为这种指针前面已经说过,这里不举例。 */ int main(){ int *result; pfunc=func;/*赋值*/ result=(int *)func();/*将void*转换成int**/ func(); pfunc(); return 0; } /* * 编译上面这个程序,能够“正常”通过,但是会得到警告:返回了临时局部变量 * 地址,因为局部变量放在栈中,在函数结束时会被自动释放,如果你真的想要 * 在函数中使用局部变量来返回,那么可以使用malloc来分配内存地址,malloc * 分配的内存属于进程的堆段,需要自己释放,或者程序运行结束后由C运行时 * 来释放。 * 最后,说说怎样区分下面这两个东东 * char *func(); * char (*func)(); * 记住函数()的结合性比指针*高,就可以很容易区分了,因为()高于*,所以 * char *func()中的变量func是一个函数,进一步和普通函数char func()对比 * 你就可以将char *func()中的char *看成是有一个括号括起来了。而 * char (*func)()中的func,由于加了括号,所以先和指针*结合,变成一个 * 指针,正如普通函数char function()中的function其实也是一个函数指针 * 一样,所以你可以将(*func)当成是一个普通变量。 */ |