FAT32 对目录中所有文件名总长度的限制吗?

Ste*_*ler 5 fat32 limits

我的一个客户的备份硬盘驱动器上遇到了一个奇怪的问题:该硬盘驱动器采用 FAT32 格式,昨晚我们的备份作业在子目录上抛出了一个错误,声称它无法复制必须复制的文件。

当然,我首先检查了磁盘大小,但是有足够的空间。给出的错误是0x80070052,如果我将其放入搜索引擎,我会得到如下结果:http ://www.quickonlinetips.com/archives/2007/09/how-to-fix-error-0x80070052-on-usb-闪存驱动器/

但该分区的根目录下只有 8 个文件/目录。所以我继续决定自己测试一些东西。创建一个文件(例如名为“test.txt”)确实有效。但是使用备份作业失败的文件名之一创建文件不起作用,而是出现了与上面相同的错误。我测试了一下,发现我可以在该子目录中创建一个包含 10 个字符的文件,再多一个字符,就会失败。

检测到这一点后,我在该子目录中创建了一个目录(名为“test”),并将一些文件从子目录移动到新目录中,完成后,我尝试创建一个包含 11 个字符的文件(这不起作用)之前)并且它起作用了。

现在,显然从观察来看,对于 FAT32 的单个目录内的所有文件名可以使用多少个字符,似乎存在某种硬限制,但我找不到有关该硬限制的任何信息,或者是否有其他文件系统(尤其是 NTFS) ,我猜这将是这种情况下的替代方案)具有类似的限制。

如果有人可以向我提供有关观察到的行为的信息,那就太好了!

编辑

一位同事告诉我将确切的文件夹放在另一个 FAT32 驱动器上,因为他曾经在使用特定制造商的 USB 控制器时遇到过问题。我尝试了两个来自不同制造商的 USB 记忆棒,均为 FAT32 格式,两者都显示出与上述完全相同的行为。

让您了解所涉及的文件数量:大约有 10200 个文件,每个文件的文件名长度在 80 到 110 个字符之间,不包括文件路径(这似乎无关紧要),因此大约有涉及一百万个字符。

kat*_*tce 5

如果所有文件都具有短文件名(8.3 格式),则 FAT 文件系统目录中的最大文件数为 65,536。短文件名存储在单个 32 字节条目中。

这意味着目录(文件)的最大大小为 65,536 * 32 字节,即 2,097,152 字节。

8.3 格式的短文件名由 8 个字符和可选的“.”组成。后跟最多 3 个字符。字符集有限。包含小写字母的短文件名另外存储在长文件名条目中。

如果文件名较长(长文件名),则会分布在多个 32 字节长的条目中。每个条目包含 13 个字符的文件名。如果文件名的长度不是 13 的倍数,则填充最后一个条目。

此外,每个长文件名条目都有一个短文件名条目。

2 个 32 字节条目已被“.”占用。每个目录(根目录除外)中的“..”条目。

1 32字节条目作为结束标记?

因此,目录中实际的最大文件数取决于文件名的长度。