Microsoft make things complicated

最近研究写NTFS驱动下的读写压缩/稀疏文件功能的时候被微软雷到了。

真不愧“微软让事情变得复杂 (Microsoft make things complicated)”的传闻。

压缩/占位流描述组居然可以分别存放到两个属性中.......彻底囧掉了......为了省几个字节的空间,代码复杂度起码提高一个数量级,犯得上么.......

 

然后又发现一个更囧的情况:NTFS属性中的流可以被任意拆开描述,一个10个簇长的流可以被写成10个1个簇的流!

比如:

11 08 10

LCN 10,LENGTH 08

完成可以被改成:

11 01 10 11 01 01 11 01 01 11 01 01 11 01 01 11 01 01 11 01 01 11 01 01

 

-_-b

 

也就是说,16个簇的压缩单元可能被写成16个流的描述,而不受压缩单元尺寸限制的稀疏文件,则存在无限可能......

而且还都能通过CHKDSK的检查并能被WINDOWS正常访问。

更可悲的是:这些流可能被拆开存放于多个属性中......虽然WINDOWS自身并不会这样做,但只要这是合法的,那别的程序就只能无条件的支持......

 

综上。非常简单的压缩/稀疏文件操作逻辑,理论上有演变成无聊,复杂,效率低下的多属性下流描述的修改操作的可能,而且事实上,程序必须处理此种状况。代码复杂度因为这个小小的设计巨增。

 

 

劳资痛恨微软那帮BT!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值