没有人说是按顺序排列的。按不按顺序排列是不一定的,说不定哪天谁开发出一个完全按顺序排列的,不考虑效率的文件系统也不是没有可能。

ext3在块内是按顺序的。建议先了解一下ext3的分块的基本概念再讨论。

2008/6/13 石康志 <[EMAIL PROTECTED]>:

> 完全不对!在文件系统中,文件并不是顺序排列的,也许一个1G的文件有100MB在'0, 0'->100mb地址,后面可以在'10000000,
> 10000000'->900mb,并不要求这一个G的东西全部按顺序放到一起,控制这一切的,仅仅是一个文件的地址信息(你可以把它想象成指针),所以可以通过改变地址信息控制文件。
>
> 2008/6/13 Zu <[EMAIL PROTECTED]>:
>
>> 可能是我没有把问题说清楚,我的原话是:
>>
>>
>> *有2个文件,file1和file2,大小都是4G,如果想合并file1和file2,可以 cat
>> file2>>file1来实现,这样要花几分钟时间。有没有一种办法,能把file2 "剪切"
>> 到file1中?也就是说把file2在文件系统中占用的数据块分配给file1?使用的是ext3文件系统。*
>>
>> mv
>> 的作用是把一个文件改一个名字,该文件除了文件名以外其他信息都不变,所以mv的速度特别快。mv不能把一个文件的内容移动到另一个文件的末尾去。我觉着下面shell909090说的比较有道理:
>>
>> *有点困难,因为根据我的理解,任何文件在磁盘中都是"块**"的集合存储的。如果头
>> 一个文件正好放满N块还好说,如果正好差一点,那么后面的数据按**照规则必须先
>> 填充前面的块。这样会造成后一个文件全面的内容位移**,其读写数据量没有比直接
>> 附加低多少。*
>>
>> 举例:
>> file1的文件长度是1个字节,在块大小是4k的ext3文件系统下,这个文件要占用4k的空间,也就是一个块的空间。
>> file2的文件长度是8K+1个字节,在块大小是4k的ext3文件系统下,这个文件要占用8K+4k的空间,也就是3个块的空间。
>> 如果要把file2剪切到file1的末尾,要做到比"cat file2>>file1"更快,不修改内核中的文件系统能做到吗?
>>
>> 2008/6/13 马利 <[EMAIL PROTECTED]>:
>> > 看看mv的源代码就差不多了吧,适当复用,没看出来和内核有什么关系
>> >
>> > --
>> > 马利
>> > richard.ma
>>  > --
>> > ubuntu-zh mailing list
>> > [email protected]
>> > https://lists.ubuntu.com/mailman/listinfo/ubuntu-zh
>> >
>> >
>>
>>
>>
>> --
>> 瑞豪开源VPS - 基于Linux/Xen - 最低58元/月 - 免费试用
>> http://www.RasHost.com
>>
>> --
>> ubuntu-zh mailing list
>> [email protected]
>> https://lists.ubuntu.com/mailman/listinfo/ubuntu-zh
>>
>>
>
> --
> ubuntu-zh mailing list
> [email protected]
> https://lists.ubuntu.com/mailman/listinfo/ubuntu-zh
>
>


-- 
瑞豪开源VPS - 基于Linux/Xen - 最低58元/月 - 免费试用
http://www.RasHost.com
-- 
ubuntu-zh mailing list
[email protected]
https://lists.ubuntu.com/mailman/listinfo/ubuntu-zh

回复