千锋教育-做有情怀、有良心、有品质的职业教育机构

手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  技术干货  > 链表(linkedlist)这一数据结构具体有哪些实际应用?

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

来源:千锋教育
发布人:xqq
时间: 2023-10-11 03:28:01 1696966081

一、链表(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 数组

内存空间存储结构:

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

调整大小

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

随机访问

数组:可以通过下标地址随机访问数组链表:只能通过一个节点一个节点轮询,效率低
声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。
10年以上业内强师集结,手把手带你蜕变精英
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通
免费领取
今日已有369人领取成功
刘同学 138****2860 刚刚成功领取
王同学 131****2015 刚刚成功领取
张同学 133****4652 刚刚成功领取
李同学 135****8607 刚刚成功领取
杨同学 132****5667 刚刚成功领取
岳同学 134****6652 刚刚成功领取
梁同学 157****2950 刚刚成功领取
刘同学 189****1015 刚刚成功领取
张同学 155****4678 刚刚成功领取
邹同学 139****2907 刚刚成功领取
董同学 138****2867 刚刚成功领取
周同学 136****3602 刚刚成功领取
相关推荐HOT