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

指针的深入理解(三)

这一节主要使用复习回调函数, 利用冒泡模拟实现qsort函数。

qsort

排序使用冒泡排序,主要难点在于运用元素个数和字节数以及基地址控制元素的比较:

if里面使用了一个判断函数,qsort可以排序任意的数据,原因就是因为可以自行提供要判断的数据类型。假如要判断整形,就传整数的判断函数, 要判断字符串,就传字符串的判断函数。在if语句里面,就会自行进行判断。 

cmp

width有什么用?width是一个数据的字节大小。有了一个数据的字节大小,再加上便宜的数据的个数。就能计算出某个数据相对基地址的偏移量。这样就能得到要比较的两个数据的首地址。假如比较的是整形类型,那么再传送给整形数据的比较函数。那么就能判断两个数据的大小,下面是整形的比较函数:

这里因为是传址调用。并且qsort本身不知道使用者要比较的是什么类型的数据,所以这里的形参类型是不确定的。只能使用void*类型。

Swap

判断完之后就需要进行交换。同样,qosrt不确定要进行交换的是什么类型的数据,所以只能进行内存的交换。即把需要交换的内存传送给Swap, Swap将两块内存数据进行交换。

下面是代码:

width在这里发挥了很大的作用,只要知道了要进行交换的内存的首地址,也就是比dest和src,然后width就是首地址往后的自己数,就组成了两块内存空间。Swap要做的就是交换这两块内存空间内的数据。

现在来看一下效果:

 

结构体的比较

结构体也可以进行比较。但是结构体比较的是某一成员,如果这个成员是int,就是用整形的方式进行比较。加入这个成员是字符串,那么就使用字符串的方式进行比较。

而qsort是任何数据类型都能比较的。包括结构体,只需要写一个结构体的成员的比较函数即可:

下面是比较函数。

 

 

 

http://www.lryc.cn/news/291545.html

相关文章:

  • 【Linux C | 网络编程】详细介绍 “三次握手(建立连接)、四次挥手(终止连接)、TCP状态”
  • 主从数据库MySQL服务重启步骤与注意事项
  • netlink学习
  • 地理空间分析10——空间数据分析中的地理编码与Python
  • 使用“快速开始”将数据传输到新的 iPhone 或 iPad
  • 计算机网络(第六版)复习提纲13
  • [office] excel2010双向条形图制作 #经验分享#微信
  • 优雅管理多线程异步任务 - 永动异步任务
  • 软考笔记--分布式数据库
  • vue项目中路由懒加载的三种方式
  • 【制作100个unity游戏之23】实现类似七日杀、森林一样的生存游戏6(附项目源码)
  • Cache Lab:Part A【模拟出使用LRU策略的高速缓存存储器组织结构】
  • 操作系统基础:死锁
  • Ubuntu server如何使用 Daphne + Nginx + supervisor部署 Django
  • Android 12.0 应用中监听系统收到的通知
  • SpringBoot+Redis如何实现用户输入错误密码后限制登录(含源码)
  • kotlin中的初始化问题纪录
  • Web中的转发与重定向
  • 交叉注意力融合时域、频域特征的FFT + CNN-Transformer-CrossAttention轴承故障识别模型
  • STM32读取MPU6050数据并通过角度值控制舵机运动(STM32、GY-521 MPU6050、SG90舵机、MG946舵机)
  • Unity_Playable工具使用
  • Flutter canvas 画一条波浪线 进度条
  • Java技术栈 —— Spring MVC 与 Spring Boot
  • 跟着cherno手搓游戏引擎【16】Camera和Uniform变量的封装
  • 微服务中间件 RabbitMq学习
  • 3D Gaussian Splatting-实时辐射场渲染技术
  • vue中nextTick()
  • Redis 布隆过滤器
  • 中国的茶文化:现代生活中的茶文化
  • Python正则表达式语法