c语言函数指针定义子函数 c语言定义函数指针变量

C语言函数指针定义在最上面加一句这样的定义
typedef void*(*pFn)();
pFn可以这样理解:首先pFn是一个指针,指针指向一个函数(或者说pFn是一个函数指针),此函数返回一个无类型的指针 。最终定义的变量及函数都是指针罢了,不过是指针的类型不同 。所以在编译时会有警告,说指针类型不匹配 。但对于程序来讲 , 都是可以在特定的上下文中使用的 。
运行结果是
t1,t2交替出现 。
其实void也可以换为其它的类型如int, double等
又想到一个很好的办法:
这次编译不会有警告 , 运行也不会出错 。
示例代码如下所示
#include stdio.h
long t1();
long t2();
int main()
{
long(*fn)()= (long (*)()) t1 ;
while(1){
fn = (long (*)()) fn();
}
}
long t1()
{
printf("t1\n");
return (long)t2 ;
}
long t2()
{
printf("t2\n");
return (long)t1 ;
}
c语言中的指针问题,以及子函数的调用第一个是在根据指针, 交换指针所指的数据
第二个虽然写的使用"指针"在实现, 实际上, 他是在奖p1 和p2两个本地的变量值进行交换, 而并不是奖两个地址所指向的内存单元进行交换
第二个函数你如果吧所有的int * 都改成int, 就能更清楚的看到他到底在干嘛了
C语言中指针定义函数问题因为第二个p是指针,并且指向了0,即是空,所以没有分配地址空间 , *p是不合法的 。。
第二个里面只需修改int *p = (int*)malloc(sizeof(int));头文件#include stdlib.h即可
C语言函数指针,敲黑白,讲重点,如何定义函数指针?学习了数组之后c语言函数指针定义子函数,我们知道数组是在内存中申请一块内存空间;数组名代表内存块c语言函数指针定义子函数的首地址c语言函数指针定义子函数,通过数组名可以访问内存块中c语言函数指针定义子函数的数据 。
那么,对于函数,它也是存放在内存块中的一段数据 。例如下面的函数:
voidfunc(inta)
{
printf("in func, a = %d ",a);
}
此时,定义了一个函数名是func的函数 。可以如下调用该函数:
func(100);
此时,就进入了func函数的函数体中执行 。可以看到, 函数名如同数组名一样,代表函数所在内存块的首地址。通过数组名可以访问数组在内存块中申请的内存,同理,通过函数名,可以访问函数在内存中存放的数据 。
所以,函数名就代表了该函数在内存块中存放的首地址 。那么,函数名是表示一个地址,就可以把这个地址值存放在某一个指针变量中,然后,通过指针变量访问函数名指向的函数 。
在C语言中,提供了函数指针变量,可以存放函数名表示的地址 。函数指针变量的定义格式如下:
返回数据类型 (*函数指针变量名)(形参列表)
对比函数的定义如下:
返回数据类型 函数名(形参列表)
可以看到,函数指针变量的定义,与函数的定义格式基本一样,唯一的区别是把“函数名”转换为“*(函数指针变量名)”;总结如下:
(1) 使用指针降级运算符*来定义,表示这个是一个指针 。
(2) 指针降级运算符*不可以靠近返回数据类型,例如“返回数据类*”就表示函数的返回类型是一个指针 。那么,为了让指针降级运算符*能够修饰函数指针变量,就用小括号()把指针降级运算符*与函数指针变量名包含起来 。
定义了函数指针变量之后,可以把函数名赋给函数指针变量 。因为,函数名就表示函数在内存块中的首地址,所以,可以直接把一个地址赋值给函数指针变量 。格式如下:
函数指针变量 = 函数名;
最终,可以通过函数指针变量调用函数 , 调用的格式与通过函数名调用完全一样 , 通过函数指针变量调用函数,有如下形式:
方法1:函数指针变量(实参列表);
方法2:(*函数指针变量名)(实参列表);
很多情况下,我们更倾向于使用第一种形式,因为,它的使用方式更接近于通过函数名调用函数 。
下面根据程序测试例子来看看怎么样应用函数指针变量 。
深入学习,可以交个朋友,工人人人号:韦凯峰linux编程学堂
程序运行结果如下:
深入学习,可以交个朋友,工人人人号:韦凯峰linux编程学堂
可以看到,我们定义了func函数和函数指针变量pfunc,然后,把函数名func设置给函数指针变量pfunc,最终,通过函数指针变量pfunc调用函数 。
因为函数指针变量存放的就是函数名表示的地址,所以,函数指针变量与函数名一样,可以直接通过函数指针变量调用函数 。
注意:我们在学习指针的时候 , 可以把一个int类型的变量地址赋值给int类型的指针;但是,不可以把int类型变量的地址,赋值给double类型的指针 。这就是变量数据类型不一致的问题 。
同样的道理,定义函数的时候 , 函数的返回数据类型和形参列表都不一样,所以,函数指针变量能够接收的函数名,它们定义的 函数返回数据类型和形参列表必须一致 ,此时,就如同变量与指针变量类型一致时,才可以把变量的地址赋值给指针变量一样 。
如下是一个测试例子:
深入学习,可以交个朋友,工人人人号:韦凯峰linux编程学堂
程序编译结果如下:
深入学习,可以交个朋友,工人人人号:韦凯峰linux编程学堂
可以看到,我们把func函数的形参列表修改为double,但是,函数指针变量pfunc定义的形参列表为int类型,此时 , 函数和函数指针变量的定义格式不一致 , 所以,不可以把函数名表示的地址设置给函数指针变量 。我们来总结一下:
(1) 在Ubuntu系统中,使用GCC编译,提示warning警告,但是,程序可以编译通过,可以运行 。
(2) 在Windows系统中,使用Visual Studio工具,无法编译该代码,提示类型不一致 。
(3) 从代码的严谨方面来说,是不可以设置类型不一致的数据 。所以,我们应该编写严谨的代码,函数定义的类型,与函数指针类型不一致的时候,不可以把函数名,赋值给函数指针变量 。
函数指针变量的定义很重要,我们需要牢记和理解它们使用的方式 。下面多举几个例子说明函数指针变量的定义和使用 。
intfunc(void);
int(*pfunc)(void);
pfunc = func;
此时,定义func函数 , 它的返回值类型是int类型,形参列表是void,那么,定义pfunc函数指针变量的时候,它的返回值类型与形参列表都必须与func一样 。
char* func1(intx,inty,intx);
char* (*pfunc1)(int,int,int);
pfunc1 = func1;
char* (*pfunc1)(intx,inty,intx);
我们再总结一下:
(1) 函数名表示函数在内存块中的首地址,可以直接把函数名赋值给函数指针变量;
(2) 定义函数指针变量的时候 , 函数返回数据类型和形参列表必须与要指向函数的定义一致;
【c语言函数指针定义子函数 c语言定义函数指针变量】c语言函数指针定义子函数的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于c语言定义函数指针变量、c语言函数指针定义子函数的信息别忘了在本站进行查找喔 。

    推荐阅读