FAT磁盘分配策略简说
2016-10-20 13:34
246 查看
FAT属于链接分配下的显示链接分配。即:将盘块号抽出来形成一个表(File Allocation Table),这个表创建时是在磁盘的,使用时可以调入内存,这是必然的,不然认为FAT在内存中,而内存是断电就丢失信息的存储,FAT表需要待在永久存储的地方–磁盘。
查找记录在内存中进行,显著提高了检索速度以及减少了访问磁盘的次数。
那么提一个关于FAT表项的计算问题,以形成一种FAT表结构的概念。
假定磁盘大小是1KB,对于540MB的硬盘,其文件分配表FAT最少需要占用多少存储空间。
分析:这里之所以说最少,是因为我们暂时不去管表项里其他的控制位,只管最基本的位数要求。也即,计算出多少磁盘块后,对应就有多少个表项。那么表项有多大呢?就需要根据表项的数目推导出离散的位数需要多少了,即二进制位有n位,
则2n=表项个数
所以问题变得极为简单:540MB÷1KB=540K个表项,29=512<540<210
因此需要20位来表示一个表项。
一个表项占用20bits÷8=2.5B
也不必特别考虑对齐,因此,540K个表项共占用磁盘空间大小是:540K×2.5B=1350KB。
查找记录在内存中进行,显著提高了检索速度以及减少了访问磁盘的次数。
那么提一个关于FAT表项的计算问题,以形成一种FAT表结构的概念。
假定磁盘大小是1KB,对于540MB的硬盘,其文件分配表FAT最少需要占用多少存储空间。
分析:这里之所以说最少,是因为我们暂时不去管表项里其他的控制位,只管最基本的位数要求。也即,计算出多少磁盘块后,对应就有多少个表项。那么表项有多大呢?就需要根据表项的数目推导出离散的位数需要多少了,即二进制位有n位,
则2n=表项个数
所以问题变得极为简单:540MB÷1KB=540K个表项,29=512<540<210
因此需要20位来表示一个表项。
一个表项占用20bits÷8=2.5B
也不必特别考虑对齐,因此,540K个表项共占用磁盘空间大小是:540K×2.5B=1350KB。
相关文章推荐
- [ext4]07 磁盘布局 - 块/inode分配策略
- [ext4]07 磁盘布局 - 块/inode分配策略
- ubuntu磁盘分配策略
- 垃圾收集器与内存分配策略
- Linux系统--从malloc中窥探Linux内存分配策略
- netapp 磁盘分配
- java垃圾回收那点事(三)不同gc策略的heap分配
- commons-pool2对象池分配回收策略
- DRUID: 任务分配策略配置
- JVM的内存分配与垃圾回收策略
- FAT格式磁盘镜像制作方法
- JVM内存分配与回收策略
- Java 内存分配策略
- java jvm 内存分配和回收策略
- 动态分区的分配策略
- 《深入理解Java虚拟机》笔记 第三章 内存分配与回收策略
- JVM 垃圾收集器与内存分配策略(1)
- Java虚拟机垃圾回收(四) 总结:内存分配与回收策略 方法区垃圾回收 以及 JVM垃圾回收的调优方法
- Java堆内存分配策略(Xmx和Xms)
- MysqL 磁盘写入策略之innodb_flush_log_at_trx_commit