操作系统==二分查找

文章目录

概述

最近看到操作系统的一些代码,觉得蛮有意思,拿出来看看,今天看下二分查找的。

二分查找

二分查找,又叫折半查找,可以参考以前写的文章,二分查找

代码

操作系统的二分查找,代码如下:

cpp 复制代码
void *bsearch(const void *key, const void *base, size_t num, size_t size,
	      int (*cmp)(const void *key, const void *elt))
{
	const char *pivot;
	int result;

	while (num > 0) {
		pivot = base + (num >> 1) * size;
		result = cmp(key, pivot);

		if (result == 0)
			return (void *)pivot;

		if (result > 0) {
			base = pivot + size;
			num--;
		}
		num >>= 1;
	}

	return NULL;
}
EXPORT_SYMBOL(bsearch);

小结

本篇写了操作系统的一个二分查找的代码,可以参考下之前的代码,当然,操作系统是对c++写的,有兴趣,可以看看这里。操作系统的二分查找,还是很有意思的,应用范围也更广。可以看看,OK,这篇结束。

相关推荐
charlie1145141915 小时前
从0开始的操作系统手搓教程27:下一步,实现我们的用户进程
学习·架构·系统架构·操作系统·教程·手搓教程·用户线程
GoGeekBaird9 小时前
69天探索操作系统-第50天:虚拟内存管理系统
后端·操作系统
JohnYan9 小时前
工作笔记 - btop安装和使用
后端·操作系统
腾源会12 小时前
OCAI + DeepSeek满血版双buff加成,OS运维从此告别焦虑
开源·操作系统·deepseek
七七知享15 小时前
2024 Qiniu 跨平台 Qt 高级开发全解析
开发语言·qt·零基础·操作系统·跨平台·qt5·精通
塞尔维亚大汉17 小时前
OpenHarmony轻量系统服务管理samgr-feature赏析及实现
操作系统·嵌入式·harmonyos
塞尔维亚大汉2 天前
OpenHarmony轻量系统服务管理samgr-service赏析
操作系统·嵌入式·harmonyos
charlie1145141912 天前
从0开始的操作系统手搓教程33:挂载我们的文件系统
学习·系统架构·操作系统·教程·文件系统·手搓教程
charlie1145141912 天前
IMX6ULL驱动开发uboot篇02
驱动开发·学习·操作系统·内核·教程·uboot
Once_day2 天前
Linux之kernel(1)系统基础理论(6)
linux·操作系统