当前位置: 首页 > news >正文

指针5.回调函数与qsort

今天来学习回调函数与qsort

在这里插入图片描述

目录

  • 1.回调函数
    • 实现模拟计算器代码的简化
      • 原代码
      • 运行结果
      • 简化代码
      • 运行结果
  • qsort函数排序整型数据
    • 代码
    • 运行结果
  • qsort排序结构数据
    • 代码
  • qsort函数的模拟实现
    • 代码
    • 运行结果
  • 总结

1.回调函数

回调函数就是⼀个通过函数指针调用的函数。
如果你把函数的指针(地址)作为参数传递给另⼀个函数,
当这个指针被用来调用其所指向的函数时,被调用的函数就是回调函数
回调函数不是由该函数的实现方直接调用,而是在特定的事件或条件发生时由另外的一方调用的,
用于对该事件或条件进行响应。

实现模拟计算器代码的简化

原代码


#include<stdio.h>int add(int x, int y)
{return x + y;
}int sub(int x, int y)
{return x - y;
}int mul(int x, int y)
{return x * y;
}int div(int x, int y)
{return x / y;
}int main()
{int input = 1;int x = 0;int y = 0;int ret = 0;do{printf("请选择:\n");printf("*************************************\n");printf("******   1.add     2.sub       ******\n");printf("******   3.mul     4.div       ******\n");printf("*************************************\n");scanf("%d", &input);switch(input){case 1:printf("请输入两个数\n");scanf("%d %d", &x, &y);ret = add(x, y);printf("ret=%d\n", ret);break;case 2:printf("请输入两个数\n");scanf("%d %d", &x, &y);ret = sub(x, y);printf("ret=%d\n", ret);break;case 3:printf("请输入两个数\n");scanf("%d %d", &x, &y);ret = mul(x, y);printf("ret=%d\n", ret);break;case 4:printf("请输入两个数\n");scanf("%d %d", &x, &y);ret = div(x, y);printf("ret=%d\n", ret);break;case 0:printf("退出程序\n");break;defualt:printf("请重新输入:\n");break;}} while (input);return 0;
}

运行结果

在这里插入图片描述

简化代码


#include<stdio.h>int add(int x, int y)
{return x + y;
}int sub(int x, int y)
{return x - y;
}int mul(int x, int y)
{return x * y;
}int div(int x, int y)
{return x / y;
}void calc(int(*pf)(int x, int y))
{int ret = 0;int x = 0;int y = 0;printf("请输入x和y的值\n");scanf("%d %d", &x,&y);ret = pf(x, y);printf("结果为:%d\n", ret);
}
int main()
{int input = 1;do{printf("请选择:\n");printf("*************************************\n");printf("******   1.add     2.sub       ******\n");printf("******   3.mul     4.div       ******\n");printf("*************************************\n");scanf("%d", &input);switch (input){case 1:calc(add);break;case 2:calc(sub);break;case 3:calc(mul);break;case 4:calc(div);break;case 0:printf("退出程序\n");break;defualt:printf("请重新输入:\n");break;}} while (input);return 0;
}

运行结果

在这里插入图片描述

qsort函数排序整型数据

代码


#include <stdio.h>
//qosrt函数的使⽤:实现⼀个⽐较函数
int int_cmp(const void* p1, const void* p2)
{return (*(int*)p1 - *(int*)p2);
}
int main()
{int arr[] = { 1, 3, 5, 7, 9, 2, 4, 6, 8, 0 };int i = 0;qsort(arr, sizeof(arr) / sizeof(arr[0]), sizeof(int), int_cmp);for (i = 0; i < sizeof(arr) / sizeof(arr[0]); i++){printf("%d ", arr[i]);}printf("\n");return 0;
}

运行结果

在这里插入图片描述

qsort排序结构数据

代码


struct Stu //学⽣
{char name[20];//名字int age;//年龄
};
//假设按照年龄来⽐较
int cmp_stu_by_age(const void* e1, const void* e2)
{return ((struct Stu*)e1)->age - ((struct Stu*)e2)->age;
}
//strcmp - 是库函数,是专⻔⽤来⽐较两个字符串的⼤⼩的
//假设按照名字来⽐较
int cmp_stu_by_name(const void* e1, const void* e2)
{return strcmp(((struct Stu*)e1)->name, ((struct Stu*)e2)->name);
}
//按照年龄来排序
void test2()
{struct Stu s[] = { {"zhangsan", 20}, {"lisi", 30}, {"wangwu", 15} };int sz = sizeof(s) / sizeof(s[0]);qsort(s, sz, sizeof(s[0]), cmp_stu_by_age);
}
//按照名字来排序
void test3()
{struct Stu s[] = { {"zhangsan", 20}, {"lisi", 30}, {"wangwu", 15} };int sz = sizeof(s) / sizeof(s[0]);qsort(s, sz, sizeof(s[0]), cmp_stu_by_name);
}int main()
{test2();test3();return 0;
}

qsort函数的模拟实现

代码


#include <stdio.h>
int int_cmp(const void* p1, const void* p2)
{return (*(int*)p1 - *(int*)p2);
}
void _swap(void* p1, void* p2, int size)
{int i = 0;for (i = 0; i < size; i++){char tmp = *((char*)p1 + i);*((char*)p1 + i) = *((char*)p2 + i);*((char*)p2 + i) = tmp;}
}
void bubble(void* base, int count, int size, int(*cmp)(void*, void*))
{int i = 0;int j = 0;for (i = 0; i < count - 1; i++){for (j = 0; j < count - i - 1; j++){if (cmp((char*)base + j * size, (char*)base + (j + 1) * size) > 0){_swap((char*)base + j * size, (char*)base + (j + 1) * size,size);}}}
}
int main()
{int arr[] = { 1, 3, 5, 7, 9, 2, 4, 6, 8, 0 };int i = 0;bubble(arr, sizeof(arr) / sizeof(arr[0]), sizeof(int), int_cmp);for (i = 0; i < sizeof(arr) / sizeof(arr[0]); i++){printf("%d ", arr[i]);}printf("\n");return 0;
}

运行结果

在这里插入图片描述

总结

今天学习了回调函数的概念及应用,认识了qsort函数的使用及运用回调函数知识完成模拟实现,希望大家加强练习巩固

对回调函数与qsort的分享就到这里了,如果感觉不错,希望可以给博主点个赞或者关注,感谢大家的支持,成为我继续分享的动力,还有什么问题和建议可以在评论区评论,拜拜。
在这里插入图片描述


http://www.mrgr.cn/news/16978.html

相关文章:

  • JAVA JDBC MYSQL案例
  • Java多线程入门介绍
  • JAVA开源项目 加油站管理系统 计算机毕业设计
  • 【大模型】Agent基础知识
  • @ConfigurationProperties 注解分析
  • 双链表算法的基本实现
  • LeetCode_sql_day20(1398.购买了产品A和产品B却没有购买产品C的顾客)
  • 大模型辅助软件开发,助力工程师的开发之路
  • sqli-labs靶场通关攻略(51-60)
  • 深入探索C语言中的各种Sleep方法
  • 一分钟学会系列-1电烙铁(焊台)
  • 【惊天BUG】select * from 表 where value = 0;查询结果让大师兄都傻眼了
  • 大模型web服务部署—lobe-chat 部署
  • 6种方法:如何克服编程挫折,找到突破的学习方法
  • 折叠cell的学习
  • 【Python百日进阶-Web开发-Peewee】Day298 - 骇客 Hacks
  • 计算机毕业设计选题推荐-公司考勤管理系统-Java/Python项目实战
  • python 地理抠图
  • 爬虫常用模板
  • 足浴城消费系统小程序的设计