zoukankan      html  css  js  c++  java
  • 回调函数

      有点类似模板的功能,可以使用函数指针作为参数,当调用函数时,使用void *进行传递参数,细致比较时,再用int *之类的进行强制转换。回调函数,其实就是在参数中定义函数,调用时,回到主函数去调用这个函数。仔细用法如下:

    首先定义查找函数

    Node * search_list(Node *node, void const *value, int (*compare)(void const *,void const *)){
        while(node!=NULL){
            if(compare(&node->data,value) == 0 )
                break;
            node = node->next;
        }
        return node;
    }

    比较函数

    int compare_ints(void const *a,void const *b){
        if( *(int *)a == *(int *)b)
            return 0;
        else
            return 1;
    }

    函数中的调用

        int *desire = (int *)malloc(sizeof(int));
        *desire = 3;
        Node *n1 = (Node *)malloc(sizeof(Node)); 
        n1 = search_list(L->next,desire,compare_ints);
        if(n1!=NULL)
            printf("找到了%d",n1->data);

    全部代码

      1 #include <stdio.h>
      2 #include <stdlib.h>
      3 
      4 typedef struct Node{
      5     int data;
      6     struct Node * next;
      7 }Node;
      8 
      9 void createList(Node * L,int len);
     10 void showList(Node *L);
     11 void clearList(Node *L);
     12 void getNode(Node *L,int n,Node *tar);
     13 int insertNode(Node *L,int n,int num);
     14 int deleteNode(Node *L,int n);
     15 Node * search_list(Node *node, void const *value, int (*compare)(void const *,void const *));
     16 int compare_ints(void const *a,void const *b);
     17 
     18 int main()
     19 {
     20     Node *L= (Node *)malloc(sizeof(Node));
     21 
     22     createList(L,5);
     23     showList(L);
     24 
     25     Node *tar= (Node *)malloc(sizeof(Node));
     26     getNode(L,3,tar);
     27     printf("the third is:%d
    ",tar->data);
     28     
     29     if(insertNode(L,3,0))
     30         showList(L);
     31     
     32     printf("回调函数:
    ");
     33     int *desire = (int *)malloc(sizeof(int));
     34     *desire = 3;
     35     Node *n1 = (Node *)malloc(sizeof(Node)); 
     36     n1 = search_list(L->next,desire,compare_ints);
     37     if(n1!=NULL)
     38         printf("找到了%d",n1->data);
     39 
     40     /*
     41     if(deleteNode(L,3))
     42         showList(L);
     43 
     44     clearList(L);
     45     showList(L);
     46     */
     47 
     48     /**desire = 9;
     49     Node *n2 = search_list(L,desire,compare_ints);
     50     if(n2!=NULL)
     51         printf("找到了%d",n2->data);
     52     *desire = 7;
     53     Node *n3 = search_list(L,desire,compare_ints);
     54     if(n3!=NULL)
     55         printf("找到了%d",n3->data);*/
     56     getchar();
     57     return 0;
     58 }
     59 Node * search_list(Node *node, void const *value, int (*compare)(void const *,void const *)){
     60     while(node!=NULL){
     61         if(compare(&node->data,value) == 0 )
     62             break;
     63         node = node->next;
     64     }
     65     return node;
     66 }
     67 int compare_ints(void const *a,void const *b){
     68     if( *(int *)a == *(int *)b)
     69         return 0;
     70     else
     71         return 1;
     72 }
     73 
     74 void createList(Node * L,int len){
     75     int i;
     76     Node * p;
     77     L->next = NULL;
     78     for(i=0;i<len;i++){
     79         p = (Node *)malloc(sizeof(Node));
     80         p->data = 2*i+1;
     81         p->next = L->next;
     82         L->next = p;
     83     }
     84 }
     85 
     86 void showList(Node *L){
     87     Node *p = (Node *)malloc(sizeof(Node));
     88     p=L->next;
     89     while(p){
     90         printf("%d->",p->data);
     91         p=p->next;
     92     }
     93     printf("null
    ");
     94     free(p);
     95 }
     96 
     97 void clearList(Node *L){
     98     Node *p,*q;
     99     p=L->next;
    100     while(p){
    101         q=p->next;
    102         free(p);
    103         p=q;
    104     }
    105     L->next=NULL;
    106 }
    107 
    108 void getNode(Node *L,int n,Node *tar){
    109     int i=1;
    110     Node *p;
    111     p=L->next;
    112     while(p && i<n){
    113         p=p->next;
    114         i++;
    115     }
    116     if(!p || i>n)
    117         printf("error!");
    118     tar->data=p->data;
    119 }
    120 
    121 int insertNode(Node *L,int n,int num){
    122     int i=1;
    123     Node *p = L->next;
    124     while( p && i<n-1){
    125         p=p->next;
    126         i++;
    127     }
    128     if(!p || i>n-1)
    129         return 0;
    130     Node *q = (Node *)malloc(sizeof(Node));
    131     q->data = num;
    132     q->next = p->next;
    133     p->next = q;
    134     return 1;
    135 }
    136 
    137 int deleteNode(Node *L,int n){
    138     int i=1;
    139     Node *p = L->next;
    140     Node *q;
    141     while( p->next && i<n-1){
    142         p=p->next;
    143         i++;
    144     }
    145     if( !(p->next) || i>n-1)
    146         return 0;
    147     q=p->next;
    148     p->next = q->next;
    149     free(q);
    150     return 1;
    151 }
    View Code

    运行示例

  • 相关阅读:
    1033 To Fill or Not to Fill (25分)(贪心)
    CentOS(五)--Linux系统的分区概念
    Linux安装Oracle 11G过程(测试未写完)
    【VMware虚拟化解决方案】设计和配置VMware vCenter 5.5
    CentOS(四)--Linux系统的启动级别
    CentOS(三)--初识linux的文件系统以及用户组等概念
    CentOS(二)--初识linux的一些常用命令
    CentOS(一)--CentOS6.4环境搭建
    Linux c/c++图片传输功能(中级版)
    remote uptime 服务器程序
  • 原文地址:https://www.cnblogs.com/xing901022/p/3623500.html
Copyright © 2011-2022 走看看