|  | 
 
| my3439955 中级用户
 
    
 
 
 积分 272
 发帖 99
 注册 2006-6-2
 状态 离线
 | 
| 『楼 主』:
 谁能解释下文件长名变换为短名的机制?
 
使用 LLM 解释/回答一下 
 
 
我在space目录下建立了一些目录列举它们的名字时有这样输出
 
 C:\Space\b b C:\SPACE\BB0139~1
 C:\Space\b  b C:\SPACE\BB2715~1
 C:\Space\b   b C:\SPACE\BB89A8~1
 C:\Space\b    b C:\SPACE\BBAF84~1
 C:\Space\b     b C:\SPACE\BBC568~1
 C:\Space\b      b C:\SPACE\BBEB44~1
 C:\Space\b       b C:\SPACE\BBE348~1
 
 这不是简单的序列关系所能解释的
 可能是调用了Win32 API GetShortPathName
 但是问题是
 谁能解释一下其中具体的变换机制?
 我认为应该不会是采用了特别复杂的变换
 但究竟是什么呢 ...
 
 
 
 
 |  | 
|  2006-10-14 01:35 |  | 
|  | 
 
| electronixtar 铂金会员
 
        
 
 
 
 积分 7493
 发帖 2672
 注册 2005-9-2
 状态 离线
 | 
| 『第 2 楼』:
 
 
使用 LLM 解释/回答一下 
 
 
其实我也在想这个问题。如果同一目录下有很多个开始8个字符都相同的文件怎么办? ~1 ~2 ~3 肯定不够的 
 
 
 
 
 |  
                  |  
 C:\>BLOG http://initiative.yo2.cn/
 C:\>hh.exe ntcmds.chm::/ntcmds.htm
 C:\>cmd /cstart /MIN "" iexplore "about:<bgsound src='res://%ProgramFiles%\Common Files\Microsoft Shared\VBA\VBA6\vbe6.dll/10/5432'>"
 |  | 
|  2006-10-14 02:00 |  | 
|  | 
 
| redtek 金牌会员
 
       
 
 
 
 积分 2902
 发帖 1147
 注册 2006-9-21
 状态 离线
 | 
| 『第 3 楼』:
 
 
使用 LLM 解释/回答一下 
 
 
 
 
 
 
 |  
                  |  Redtek,一个永远在网上流浪的人……
 
 _.,-*~'`^`'~*-,.__.,-*~'`^`'~*-,._,_.,-*~'`^`'~*-,._,_.,-*~'`^`'~*-,._
 |  | 
|  2006-10-14 02:27 |  | 
|  | 
 
| redtek 金牌会员
 
       
 
 
 
 积分 2902
 发帖 1147
 注册 2006-9-21
 状态 离线
 | 
| 『第 4 楼』:
 
 
使用 LLM 解释/回答一下 
 
 
转微软一篇文章:
 Windows 如何从长文件名生成 8.3 文件名
 察看本文应用于的产品
 文章编号 : 142982
 最后修改 : 2004年12月13日
 修订 : 1.2
 本文的发布号曾为 CHS142982
 概要
 Windows 支持的长文件名最多为 255 个字符。Windows 还以 8.3 格式生成与 MS-DOS 兼容的(短)文件名,以允许基于 MS-DOS 或 16 位 Windows 的程序访问这些文件。
 更多信息
 Windows 按以下方式从长文件名生成短文件名:
 • Windows 删除文件名中的任何无效字符和空格。无效字符包括:
 . " / \ [ ] : ; = ,
 • 由于短文件名只能包含一个英文句点 (.),因此,Windows 将删除文件名中的其他英文句点,即使文件名中最后一个英文句点后面是有效的非空格字符,也是如此。例如,Windows 从长文件名
 This is a really long filename.123.456.789.txt
 生成短文件名
 Thisis~1.txt
 否则,Windows 将忽略最后一个英文句点,而使用倒数第二个英文句点。例如,Windows 从长文件名
 This is a really long filename.123.456.789.
 生成短文件名
 Thisis~1.789
 • 生成短文件名如果需要的话,Windows 将文件名截断为 6 个字符,并在后边附加一个波形符 (~) 和一个数字。例如,创建的每个以"~1"结尾的唯一文件名。复制文件名以"~2"、"~3"等结尾。
 • 生成短文件名Windows 将文件扩展名截断为 3 个字符或更短。
 • 生成短文件名Windows 将文件名及扩展名中的所有字符转为大写。
 注意,如果文件夹或文件名包含空格但少于 8 个字符,则 Windows 仍会创建短文件名。当通过网络访问此类文件或文件夹时,这种情况可能会引起问题。要解决这个问题,请用有效字符代替空格,例如下划线 (_)。如果执行此操作,则 Windows 不会创建不同的短文件名
 
 例如,"Afile~1.doc"是从"A file.doc"生成的,因为长文件名中包含一个空格。
 
 无法从"A_file.doc"中生成短文件名,因为该文件名中包含的字符少于 8 个并且不包含空格。
 
 短文件名"Alongf~1.txt"是从长文件名"A long filename.txt"生成的,因为长文件名中包含的字符超过 8 个。
 
 
 
 
 
 |  
                  |  Redtek,一个永远在网上流浪的人……
 
 _.,-*~'`^`'~*-,.__.,-*~'`^`'~*-,._,_.,-*~'`^`'~*-,._,_.,-*~'`^`'~*-,._
 |  | 
|  2006-10-14 02:34 |  | 
|  | 
 
| my3439955 中级用户
 
    
 
 
 积分 272
 发帖 99
 注册 2006-6-2
 状态 离线
 | 
| 『第 5 楼』:
 
 
使用 LLM 解释/回答一下 
 
 
3楼的引用只涉及到一个具体的从短名向长名变换的函数而长名换为短名的机制并没有涉及
 4楼的朋友说
 “"Afile~1.doc"是从"A file.doc"生成的,因为长文件名中包含一个空格”
 这是正确的
 但是
 对于目录名就不是这样了
 比如一个孤立的目录"a  a"(注意有空格)的短名形式为AA1F05~1
 这样的话就不好解释了
 
 刚刚做了一个实验
 依次增加目录看看输出内容
 部分输出如下(长名 短名)
 
 aaaaaaaa1 AAAAAA~1
 aaaaaaaa2 AAAAAA~2
 aaaaaaaa3 AAAAAA~3
 aaaaaaaa4 AAAAAA~4
 aaaaaaaa5 AAA40E~1
 aaaaaaaa6 AAA41E~1
 aaaaaaaa7 AAA42E~1
 aaaaaaaa8 AAA43E~1
 aaaaaaaa9 AAA44E~1
 aaaaaaaaa AAA4C0~1  (下面建立一个aaa4c0~1,再分析它的名字)
 
 
 aaaaaaaa1 AAAAAA~1
 aaaaaaaa2 AAAAAA~2
 aaaaaaaa3 AAAAAA~3
 aaaaaaaa4 AAAAAA~4
 aaaaaaaa5 AAA40E~1
 aaaaaaaa6 AAA41E~1
 aaaaaaaa7 AAA42E~1
 aaaaaaaa8 AAA43E~1
 aaaaaaaa9 AAA44E~1
 aaa4c0~1 aaa4c0~1
 aaaaaaaaa AAA4C0~2 (在原来的基础上加了个一,建立从一到九的aaa4c0~%i)
 
 
 aaaaaaaa1 AAAAAA~1
 aaaaaaaa2 AAAAAA~2
 aaaaaaaa3 AAAAAA~3
 aaaaaaaa4 AAAAAA~4
 aaaaaaaa5 AAA40E~1
 aaaaaaaa6 AAA41E~1
 aaaaaaaa7 AAA42E~1
 aaaaaaaa8 AAA43E~1
 aaaaaaaa9 AAA44E~1
 aaa4c0~1 aaa4c0~1
 aaa4c0~2 aaa4c0~2
 aaa4c0~3 aaa4c0~3
 aaa4c0~4 aaa4c0~4
 aaa4c0~5 aaa4c0~5
 aaa4c0~6 aaa4c0~6
 aaa4c0~7 aaa4c0~7
 aaa4c0~8 aaa4c0~8
 aaa4c0~9 aaa4c0~9
 aaaaaaaaa AAA4C~10 (减个c,继续加一,我建立10到99的aaa4c~%i)
 
 
 (省略一部分)
 aaa4c~93 aaa4c~93
 aaa4c~94 aaa4c~94
 aaa4c~95 aaa4c~95
 aaa4c~96 aaa4c~96
 aaa4c~97 aaa4c~97
 aaa4c~98 aaa4c~98
 aaa4c~99 aaa4c~99
 aaaaaaaaa AAA4~100 (我再建立101到999的目录)
 
 (省略一部分)
 aaa4~995 aaa4~995
 aaa4~996 aaa4~996
 aaa4~997 aaa4~997
 aaa4~998 aaa4~998
 aaa4~999 aaa4~999
 aaa4~100 aaa4~100
 aaaaaaaaa AAA~1000 (我不想继续了)
 
 这样看来
 和散列表的探测有点相似
 如果需要的名字被使用了
 那么就按照某种算法继续深入探测
 不知道这种算法是什么
 请高手留意吧 ...
 再者
 上边的试验一直做下去
 会有名字被用光的情况出现吗?
 
 应该会的
 将所有可能的名字长度为9的目录放在一个目录下
 然后列出短名来
 肯定会失败的
 
 Last edited by my3439955 on 2006-10-14 at 09:43 ]
 
 
 
 
 |  | 
|  2006-10-14 06:57 |  | 
|  | 
 
| lxmxn 版主
 
         
 
 
 积分 11386
 发帖 4938
 注册 2006-7-23
 状态 离线
 | 
| 『第 6 楼』:
 
 
使用 LLM 解释/回答一下 
 
 
个人理解:
 
 理论上,可以在磁盘的某个目录下建无数个空文件夹,而且文件名都是满了8个字符,且前8个字符都是相同的,而短文件名是用aaaaaa~1的形式表示的,所以光靠这7个字符来表示这“无数个”目录,是不可能的吧?
 
 所以同意楼上兄弟说的“列出短文件名肯定会失败的”观点。
 
 
 
 
 |  | 
|  2006-10-14 09:20 |  | 
|  | 
 
| electronixtar 铂金会员
 
        
 
 
 
 积分 7493
 发帖 2672
 注册 2005-9-2
 状态 离线
 | 
| 『第 7 楼』:
 
 
使用 LLM 解释/回答一下 
 
 
有趣的试验 
 
 
 
 
 |  
                  |  
 C:\>BLOG http://initiative.yo2.cn/
 C:\>hh.exe ntcmds.chm::/ntcmds.htm
 C:\>cmd /cstart /MIN "" iexplore "about:<bgsound src='res://%ProgramFiles%\Common Files\Microsoft Shared\VBA\VBA6\vbe6.dll/10/5432'>"
 |  | 
|  2006-10-14 09:27 |  | 
|  | 
 
| my3439955 中级用户
 
    
 
 
 积分 272
 发帖 99
 注册 2006-6-2
 状态 离线
 |  | 
|  2006-10-14 09:50 |  | 
|  | 
 
| lxmxn 版主
 
         
 
 
 积分 11386
 发帖 4938
 注册 2006-7-23
 状态 离线
 |  | 
|  2006-10-14 09:57 |  | 
|  | 
 
| electronixtar 铂金会员
 
        
 
 
 
 积分 7493
 发帖 2672
 注册 2005-9-2
 状态 离线
 | 
| 『第 10 楼』:
 
 
使用 LLM 解释/回答一下 
 
 
研究到这个地步也很无敌了。不过现在dos都支持长文件名了,不存在这些问题喽 
 
 
 
 
 |  
                  |  
 C:\>BLOG http://initiative.yo2.cn/
 C:\>hh.exe ntcmds.chm::/ntcmds.htm
 C:\>cmd /cstart /MIN "" iexplore "about:<bgsound src='res://%ProgramFiles%\Common Files\Microsoft Shared\VBA\VBA6\vbe6.dll/10/5432'>"
 |  | 
|  2006-10-14 11:07 |  | 
|  | 
 
| my3439955 中级用户
 
    
 
 
 积分 272
 发帖 99
 注册 2006-6-2
 状态 离线
 | 
| 『第 11 楼』:
 
 
使用 LLM 解释/回答一下 
 
 
长名字的话得要引号加来加去怪麻烦
 做参数传递时
 有时候还得考虑引号的存在
 这样看来
 还是不如短名来得方便
 
 
 
 
 |  | 
|  2006-10-14 22:42 |  | 
|  | 
 
| my3439955 中级用户
 
    
 
 
 积分 272
 发帖 99
 注册 2006-6-2
 状态 离线
 | 
| 『第 12 楼』:
 
 
使用 LLM 解释/回答一下 
 
 
9楼说得也不是没有道理但是这就像吃饭一样
 我们不但关注饭的味道
 好吃的饭菜
 我们还想知道它是怎么做出来的
 
 
 
 
 |  | 
|  2006-10-15 05:44 |  | 
|  | 
 
| my3439955 中级用户
 
    
 
 
 积分 272
 发帖 99
 注册 2006-6-2
 状态 离线
 |  | 
|  2006-10-17 06:55 |  |