链表(linkedlist)这一数据结构具体实际应用,最显著的应用就是文件系统。你格式化硬盘时会让你选择fat32、ntfs格式,其实就是让你选择存储链表空间规模及格式。为提高系统效率,有时需要做文件碎片整理。
一、链表(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 数组
内存空间存储结构:
- 数组:存储在一组连续的内存空间中
- 链表:节点分散在各自不同的内存空间中
调整大小
- 数组:增加或减少元素个数,大多需要重新分配一整块连续的内存空间,然后复制原有数据
- 链表:节点不需要连续地存储在一块地方,增加和删除节点,非常方便
随机访问
- 数组:可以通过下标地址随机访问数组
- 链表:只能通过一个节点一个节点轮询,效率低