全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货

链表(linkedlist)这一数据结构具体有哪些实际应用?

发布时间:2023-10-11 03:28:01
发布人:xqq

一、链表(linkedlist)这一数据结构具体有哪些实际应用

链表(linkedlist)这一数据结构具体实际应用,最显著的应用就是文件系统。你格式化硬盘时会让你选择fat32、ntfs格式,其实就是让你选择存储链表空间规模及格式。为提高系统效率,你时需要做文件碎片整理。

这说明一个文件的数据不一定是连续存放的,那么操作系统是如何知道把不连续的数据合成一个文件提供给你的呢?其实就是通过访问一个指向文件数据区的链表得到的。操作系统通常会把一个硬盘的文件区域划分为3个部分:簇链表空间(FAT)/根目录区(Root)、数据区,而数据区是按指定空间大小分为一簇簇,并编号,假入一个文件数据分布在1/3/5簇,那么目录区该文件目录后面会跟随一个指针指向1,接着在FAT编号为1的指针指向3,3指向5,5没有指向,通常链表是以NULL结束,但文件系统是以-1结束。所以文件系统通过访问目录(头指针head)、FAT区(链表区相当去申请到的堆空间)得到一个完整的链表1-3-5,再通过计算获取文件数据所在的簇,最后得到数据。

由于链表属于环环相扣的串行数据,任何一环断开,这个链条就坏了,所以文件系统通常会有一个备份FAT,确保一个损坏可以恢复。


延伸阅读:

二、链表 vs 数组

内存空间存储结构:

数组:存储在一组连续的内存空间中链表:节点分散在各自不同的内存空间中

调整大小

数组:增加或减少元素个数,大多需要重新分配一整块连续的内存空间,然后复制原有数据链表:节点不需要连续地存储在一块地方,增加和删除节点,非常方便

随机访问

数组:可以通过下标地址随机访问数组链表:只能通过一个节点一个节点轮询,效率低
#it技术干货

相关文章

单调栈什么时候从后向前遍历,什么时候从前向后遍历?

单调栈什么时候从后向前遍历,什么时候从前向后遍历?

2023-10-11
mysql索引结构有哪些,各自的优劣是什么?

mysql索引结构有哪些,各自的优劣是什么?

2023-10-11
操作系统几种主要的页面置换算法分别是用什么数据结构实现的?

操作系统几种主要的页面置换算法分别是用什么数据结构实现的?

2023-10-11
邻接表为什么不用set而用vector存储?

邻接表为什么不用set而用vector存储?

2023-10-11

最新文章

常见网络安全面试题:Windows常用的命令有哪些?

常见网络安全面试题:Windows常用的命令有哪些?

2023-10-09
常见网络安全面试题:根据设备告警如何展开排查?

常见网络安全面试题:根据设备告警如何展开排查?

2023-10-09
常见网络安全面试题:mysql加固呢?(数据库加固)

常见网络安全面试题:mysql加固呢?(数据库加固)

2023-10-09
常见网络安全面试题:windows和linux加固?(操作系统加固)

常见网络安全面试题:windows和linux加固?(操作系统加固)

2023-10-09
在线咨询 免费试学 教程领取