C++之双向链表与哈希链表用法区别实例(二百六十八)

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长!

优质专栏:Audio工程师进阶系列原创干货持续更新中……】🚀
优质专栏:多媒体系统工程师系列原创干货持续更新中……】🚀
优质视频课程:AAOS车载系统+AOSP14系统攻城狮入门实战课原创干货持续更新中……】🚀

人生格言: 人生从来没有捷径,只有行动才是治疗恐惧和懒惰的唯一良药.

更多原创,欢迎关注:Android系统攻城狮

欢迎关注Android系统攻城狮

1.前言

本篇目的:在阅读Linux内核代码时,发现Binder驱动中的双向链表和哈希链表的挺有意思,分享给大家。

2.双向链表与哈希链表介绍

  • 在Android的Binder区域中,双向链表(struct list_head)和哈希链表(struct hlist_node)是两种不同的数据结构,它们在实现中有一些区别和各自的作用。
  • 首先,让我们了解这两种数据结构的基本概念:
  1. 双向链表(struct list_head)

    • 双向链表是一种数据结构,其中每个节点都包含指向前一个节点和后一个节点的指针。这使得在双向链表中,节点可以双向遍历。
    • 在Linux内核中,双向链表是一种常见的数据结构,用于连接内核中的各种对象,例如进程、文件等。
    • 在Binder区域,双向链表常用于维护连接Binder驱动程序的客户端和服务端之间的通信通道。它们可以帮助管理Binder对象的生命周期和通信路线。
  2. 哈希链表(struct hlist_node)

    • 哈希链表是一种特殊的链表结构,它与传统链表不同之处在于,每个节点可能连接到一个链表桶中,而不是简单地按照顺序连接。
    • 在哈希链表中,节点被散列到特定的桶中,以提高检索效率。这使得在大型数据集中查找特定项的时间复杂度得到了显著改善。
    • 在Android的Binder区域,哈希链表通常用于管理Binder节点的分配和释放。通过哈希链表,系统可以更有效地管理Binder对象的分配和回收,以提高性能和资源利用率。

现在来比较双向链表和哈希链表在Binder区域中的作用和区别:

  1. 作用

    • 双向链表用于维护Binder通信通道的连接关系,帮助管理客户端和服务端之间的通信路线。
    • 哈希链表用于管理Binder对象的分配和释放,以提高资源管理的效率和性能。
  2. 区别

    • 双向链表提供了顺序访问节点的能力,而哈希链表则通过散列将节点分布到不同的桶中,提高了查找效率。
    • 双向链表的节点包含指向前一个和后一个节点的指针,而哈希链表的节点可能包含指向桶中下一个节点的指针。
  • 总的来说,在Android的Binder区域中,双向链表和哈希链表都是重要的数据结构,用于管理Binder对象和通信通道,但它们在实现方式和作用上略有不同,以满足不同的需求和优化性能。

Android的Binder驱动数据结构

  • 在Android的Binder驱动数据结构中,struct list_head 表示双向链表,而 struct hlist_head 和 struct hlist_node 表示哈希链表的头部和节点。

  • 1.双向链表 struct list_head

  • 每个 struct list_head 结构包含两个指针,分别指向下一个节点和前一个节点,因此构成了一个双向链表。

  • 用途:双向链表通常用于存储元素的有序集合,并且支持在常量时间内对链表中的元素进行插入、删除和前向/后向遍历。

  • 2.哈希链表 struct hlist_head 和 struct hlist_node

  • struct hlist_head 表示哈希链表的头部,其中包含一个指向链表的第一个节点的指针。

  • struct hlist_node 表示哈希链表中的节点,每个节点包含一个指向下一个节点的指针以及一个指向前一个节点指针的指针。

  • 用途:哈希链表通常用于在哈希表中解决哈希冲突。每个桶对应一个哈希链表,这样相同哈希值的键值对可以通过链表链接在一起。

3.代码实例

<1>.双向链表代码实例

#include <iostream>// 双向链表节点结构
struct list_head {struct list_head *next, *prev;
};int main() {// 创建双向链表struct list_head list;struct list_head node1, node2, node3;// 初始化双向链表头list.next = &node1;list.prev = &node3;// 初始化节点node1.next = &node2;node1.prev = &list;node2.next = &node3;node2.prev = &node1;node3.next = &list;node3.prev = &node2;// 遍历双向链表并打印节点地址struct list_head *pos;std::cout << "双向链表节点地址:";for (pos = list.next; pos != &list; pos = pos->next) {std::cout << pos << " ";}std::cout << std::endl;return 0;
}

<2>.哈希链表代码实例

#include <iostream>// 哈希链表头结构
struct hlist_head {struct hlist_node *first;
};// 哈希链表节点结构
struct hlist_node {struct hlist_node *next, **pprev;
};int main() {// 创建哈希链表struct hlist_head hash_table[10];struct hlist_node node1, node2, node3;// 初始化哈希链表头for (int i = 0; i < 10; ++i) {hash_table[i].first = NULL;}// 初始化节点node1.next = &node2;node1.pprev = &hash_table[0].first;node2.next = &node3;node2.pprev = &node1.next;node3.next = NULL;node3.pprev = &node2.next;// 遍历哈希链表并打印节点地址std::cout << "哈希链表节点地址:";struct hlist_node *hpos;for (hpos = hash_table[0].first; hpos != NULL; hpos = hpos->next) {std::cout << hpos << " ";}std::cout << std::endl;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/795040.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Cisco Unified Communications Manager (CallManager) 15.0 SU1 - 统一通信与协作

Cisco Unified Communications Manager (CallManager) 15.0 SU1 - 统一通信与协作 思科统一通信管理器 (CallManager) 请访问原文链接&#xff1a;https://sysin.org/blog/cisco-ucm-15/&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。 作者主页&#xff1a;…

需求分析及设计定义

背景 经过不断的折腾&#xff0c;一切过程都是为了呈现输出&#xff0c;这个阶段就是要交付需求和方案的环节了&#xff0c;很多失败的项目就是上来就到这个环节&#xff0c;倒着捣鼓&#xff0c;先写个文档&#xff0c;做个原型&#xff0c;甚至提出方案&#xff0c;然后再和…

Redis 未授权访问漏洞

出现以下函数 eval函数&#xff1a;因为脚本内容必须通过eval来执行 2.luaopen_io函数&#xff1a;因为此攻击必须通过执行luaopen_io函数来获取 io库 3、.popen函数&#xff1a;恶意命令必须通过io库中的popen函数来执行&#xff0c;为什么拦截规则不是io.popen&#xff0…

状态优先级

文章目录 状态优先级1. 进程状态1.1 进程状态查看1.2 僵尸进程1.3 孤儿进程 2.进程优先级2.1 基本概念2.2 查看系统进程2.3 PRI and NI2.4 PRI vs NI 3. 查看进程优先级的命令3.1 top命令更改nice3.2 其他概念 状态优先级 1. 进程状态 看看Linux内核源代码怎么说 为了弄明白…

深入浅出 -- 系统架构之分布式系统底层的一致性

在分布式领域里&#xff0c;一致性成为了炙手可热的名词&#xff0c;缓存、数据库、消息中间件、文件系统、业务系统……&#xff0c;各类分布式场景中都有它的身影&#xff0c;因此&#xff0c;想要更好的理解分布式系统&#xff0c;必须要理解“一致性”这个概念。 其实关于…

云原生架构(微服务、容器云、DevOps、不可变基础设施、声明式API、Serverless、Service Mesh)

前言 读完本文&#xff0c;你将对云原生下的核心概念微服务、容器云、DevOps、Immutable Infrastructure、Declarative-API、Serverless、Service Mesh 等有一个相对详细的了解&#xff0c;帮助你快速掌握云原生的核心和要点。 因题主资源有限, 这里会选用部分云服务商的组件进…

LeetCode:1026. 节点与其祖先之间的最大差值(DFS Java)

目录 1026. 节点与其祖先之间的最大差值 题目描述&#xff1a; 实现代码与解析&#xff1a; DFS 原理思路&#xff1a; 1026. 节点与其祖先之间的最大差值 题目描述&#xff1a; 给定二叉树的根节点 root&#xff0c;找出存在于 不同 节点 A 和 B 之间的最大值 V&#xff…

11-1(2)-CSS 背景+CSS 精灵图

个人主页&#xff1a;学习前端的小z 个人专栏&#xff1a;HTML5和CSS3悦读 本专栏旨在分享记录每日学习的前端知识和学习笔记的归纳总结&#xff0c;欢迎大家在评论区交流讨论&#xff01; 文章目录 一、CSS 背景1 背景颜色2 背景色半透明3 背景图片4 背景平铺5 背景图片位置6 …

深度剖析:网络安全中的红蓝对抗策略

红蓝对抗 红蓝对抗服务方案 在蓝队服务中&#xff0c;作为攻击方将开展对目标资产的模拟入侵&#xff0c;寻找攻击路径&#xff0c;发现安全漏洞和隐患。除获取目标系统的关键信息&#xff08;包括但不限于资产信息、重要业务数据、代码或管理员账号等&#xff09;外&#x…

如何在iPhone上恢复永久删除的照片?

2007 年&#xff0c;Apple Inc. 推出了这款震撼人心的智能手机&#xff0c;后来被称为 iPhone。您会惊讶地发现&#xff0c;迄今为止&#xff0c;Apple Inc. 已售罄 7 亿台 iPhone 设备。根据 2023 年 8 月的一项调查数据&#xff0c;95% 的智能手机利润都落入了苹果公司的口袋…

跨平台的组播测试工具mping、udp_sender及udp_reciver的源码及使用教程

文章目录 1.前言2.mping工具编译3.mping工具使用3.1 参数说明3.1 组播播发&#xff08;-s&#xff09;3.1 组播播发&#xff08;-r&#xff09;3.3 Linux下mping测试 4.Linux组播udp_sender及udp_reciver使用4.1 udp_sender源码4.1 udp_reciver源码4.3 编译方法4.4 测试使用4.4…

android11 SystemUI入門之KeyguardPatternView解析

view层级树为&#xff1a; 被包含在 keyguard_host_view.xml中 。 <?xml version"1.0" encoding"utf-8"?> <!-- This is the host view that generally contains two sub views: the widget viewand the security view. --> <com.andro…

并发编程01-深入理解Java并发/线程等待/通知机制

为什么我们要学习并发编程&#xff1f; 最直白的原因&#xff0c;因为面试需要&#xff0c;我们来看看美团和阿里对 Java 岗位的 JD&#xff1a; 从上面两大互联网公司的招聘需求可以看到&#xff0c; 大厂的 Java 岗的并发编程能力属于标配。 而在非大厂的公司&#xff0c; 并…

Ubuntu22.04中基于Qt开发Android App

文章目录 前言在Ubuntu22.04中配置开发环境案例测试参考 前言 使用Qt开发手机应用程序是一种高效且灵活的选择。Qt作为一个跨平台的开发框架&#xff0c;为开发者提供了统一的开发体验和丰富的功能库。首先&#xff0c;Qt的跨平台性让开发者可以使用相同的代码库在不同的操作系…

Error: TF_DENORMALIZED_QUATERNION: Ignoring transform forchild_frame_id

问题 运行程序出现&#xff1a; Error: TF_DENORMALIZED_QUATERNION: Ignoring transform for child_frame_id “odom” from authority “unknown_publisher” because of an invalid quaternion in the transform (0.0 0.0 0.0 0.707) 主要是四元数没有归一化 Eigen::Quatern…

【PostgreSQL】技术传承:使用Docker快速部署PostgreSQL数据库

前言 PostgreSQL的重要贡献者Simon Riggs因一起坠机事故不幸离世。Simon Riggs是英国著名的软件与服务领导者&#xff0c;也是PostgreSQL的主要开发者和贡献者。事故发生在英国当地时间3月26日13:41分&#xff0c;当时他驾驶的私人通用航空Cirrus SR22飞机在英国达克斯福德机场…

java——文件上传

一、文件上传——简介 文件上传的简介&#xff1a;文件上传是指将本地计算机中的文件传输到网络上的服务器或另一台计算机上的过程。在 Web 开发中&#xff0c;文件上传通常指的是将用户通过 Web 页面提交的文件&#xff08;如图像、文档、音频、视频等&#xff09;传输到服务器…

设计模式总结-原型设计模式

原型设计模式 模式动机模式定义模式结构模式分析深拷贝和浅拷贝原型模式实例与解析实例一&#xff1a;邮件复制&#xff08;浅克隆&#xff09;实例二&#xff1a;邮件复制&#xff08;深克隆&#xff09; 模式动机 在面向对象系统中&#xff0c;使用原型模式来复制一个对象自…

MySQL 50 道查询题汇总,足以巩固大部分查询(附带数据准备SQL、题型分析、演示、50道题的完整SQL)

目录 MySQL 50 道查询题&#xff0c;足以巩固大部分查询数据准备&#xff1a;创建表sql添加表数据sql 50道查询题目汇总01 - 05 题&#xff1a;1、查询 “01” 语文成绩比 “02” 数学成绩高的学生的信息及课程分数2、查询 "01语文课程"比"02数学课程"成绩…

Linux云计算之网络基础9——园区网络架构项目

要求构建大型园区网络架构&#xff0c;方案如下&#xff1a; 园区A 园区c 公司B 要求&#xff1a; 1、A公司园区网络 一台汇聚层三层交换机&#xff0c;两台接入层二层交换机。 出口有一台路由器。 2、A园区有五台服务器。 分别为两台 WEB 服务器&#xff0c;…