| 
 
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 | 
  
 |