标题: 已结:关于tree命令和tree批处理的名字冲突问题
[打印本页]
作者: undiligent
时间: 2005-11-29 14:35
标题: 已结:关于tree命令和tree批处理的名字冲突问题
tree/f>>tree.txt
上边是我写的,然后我把它保存成.bat格式
我把这个bat命名为a.bat
双击执行,能够把当前文件夹下的所有的文件以树型结构显示出来
D:.
│ a.bat
│ 0401801BackAction.java
│ 0401801CsvAction.java
│ 0401801CsvJavaBean.java
│ 0401801DepotchangeAction.java
│ 0401801DepotchangeJavaBean.java
│ 0401801Form.java
│ 0401801InitAction.java
│ 0401801InitJavaBean.java
│ 0401801PrintAction.java
│ 0401801PrintJavaBean.java
│ 0401801SearchAction.java
│ tree.txt
│
└─0401801
WEE0401801.jsp
但是如果我把bat文件的名字变成tree.bat
双击执行之后,新生的tree.txt文件显示的内容如下:
D:\040180>tree/f1>>tree.txt
不知道是什么原因,那位高手有时间给我解释一下,
谢谢了

!!!
[
Last edited by willsort on 2005-11-30 at 19:54 ]
作者: willsort
时间: 2005-11-29 16:05
Re undiligent:
这是一个很典型的因为名字冲突而引起的问题。
在 MSDOS/Windows 中,tree 一般是系统提供的外部命令所使用的。与内部命令不同的是,外部命令与其他的可执行程序相比,不具有更高的名字优先权。这里提供 MSDOS 的可执行体执行优先顺序列表:
1、DOS 宏命令,由 doskey 支持
2、DOS 内部命令,由 command.com 支持
3、DOS 可执行程序(包括外部命令),由可执行程序文件支持
3-1、按照所处路径的优先级排序:用户指定路径、当前路径、%path%所指路径
3-2、按照扩展名的优先级排序: com exe bat
注意:当3-1与3-2遇到冲突时,3-1具有更高的优先级。也就是说,两个同主名的程序,一个是 %path% 路径下的 tree.exe 文件,一个是当前路径下的 tree.bat 文件,此时将优先执行后者。
也就是说,当你的批处理改为 tree.bat 之后,你点击执行它,它会执行 tree /f1 >>tree.txt 这一句,而其中的 tree 并没有被理解为 tree.exe 这个外部命令,而被理解 tree.bat 这个批处理,所以会再次执行 tree.bat 这个批处理自身,如此反复不断地递归执行下去,直到系统内部的调用堆栈用尽而被系统终止。而其命令行显示因为未被 echo off 禁止而被重定向到文件中。
避免此类问题的最好方法就是,不要以系统程序已占用的名字命名自己编写的程序。解决办法:一个是将 tree.bat 改为其他系统未占用的主名;一个是将批处理中的 tree/f 改为 tree.exe/f ;另外,将系统的 tree.exe 改名,同时修改批处理中的调用名,也是一个办法
[
Last edited by willsort on 2005-11-30 at 19:48 ]
作者: undiligent
时间: 2005-11-30 17:56
太感谢了!!学到很多东西
原来就知道是明子问题
但是不知道具体的原理
现在就明白了,谢谢楼上的解答
[
Last edited by undiligent on 2005-11-30 at 17:59 ]