1 / 4
文档名称:

函数指针的使用.doc

格式:doc   大小:21KB   页数:4页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

函数指针的使用.doc

上传人:tmm958758 2019/5/14 文件大小:21 KB

下载得到文件列表

函数指针的使用.doc

文档介绍

文档介绍:对指针的应用是C语言编程的精髓所在,而回调函数就是C语言里面对函数指针的高级应用。简而言之,回调函数是一个通过函数指针调用的函数。如果你把函数指针(函数的入口地址)传递给另一个函数,当这个函数指针被用来调用它所指向的函数时,我们就说这个函数是回调函数。为什么要使用回调函数呢?我们先看一个小例子: Node*Search_List(Node*node,constintvalue) { while(node!=NULL) { if(node->value==value) { break; } node=node->next; } returnnode; } 这个函数用于在一个单向链表中查找一个指定的值,返回保存这个值的节点。它的参数是指向这个链表第一个节点的指针以及要查找的值。这个函数看上去很简单,但是我们考虑一个问题:它只能适用于值为整数的链表,如果查找一个字符串链表,我们不得不再写一个函数,其实大部分代码和现在这个函数相同,只是第二个参数的类型和比较的方法不同。其实我们更希望令查找函数与类型无关,这样它就能用于查找存放任何类型值的链表了,因此必须改变比较的方式,而借助回调函数就可以达到这个目的。我们编写一个函数(回调函数),用于比较两个同类型的值,然后把一个指向这个函数的指针作为参数传递给查找函数,查找函数调用这个比较函数来执行比较,采用这个方法,任何类型的值得都可以进行比较。我们还必须给查找函数传递一个指向待比较的值的指针而不是值本身,也就是一个void*类型的形参,这个指针会传递给回调函数,进行最终的比较。这样的修改可以让我们传递指向任何类型的指针到查找函数,从而完成对任何类型的比较,这就是指针的好处,我们无法将字符串、数组或者结构体作为参数传递给函数,但是指向它们的指针却可以。现在,我们的查找函数就可以这样实现: NODE*Search_List(NODE*node,int(*compare)(voidconst*,voidconst*), voidconst*desired_value); { while(node!=NULL) { pare((node->value_address),desired_value)==0) { break; } node=node->next; } returnnode; } 可以看到,用户将一个函数指针传递给查找函数,后者将回调这个函数。注意这里我们的链表节点是这样定义的: typedefstructlist { void*value_address; structlist*next; }NODE; 这样定义可以让NODE*类型的指针指向存储任何类型数据的链表节点。而value_address就是指向具体数据的指针,我们把它定义为void*,表示一个指向未知类型的指针,这样链表就可以存储任何类型的数据了,而我们传递给查找函数Search_List的第一个参数就可以统一表示为:NODE*,否则,还是要分别写查找函数以适应存储不同数据类型的链表。现在,查找函数与类型无关,因为它不进行实际的比较,因此,我们必须编写针对不同类型的比较函数,这是很容易实现的,因为调用者知道链表中所包含的值的类型,如果创建几个分别包含不同类型值的链表,为每种类型编写一个比较函数就允许单个查找函数作用于所有类型的链表。下面是一个比较函数