批处理中的预处理实现代码
转载自 nxhujiee最终编辑 LJ_SunTB批处理中的【预处理】 复制代码 代码如下: @echo off set var=^^^> echo %var% pause 这句“set var=^^^>”首先也会被预处理,预处理之后var的值为“^>”。 本例的输出结果是“>”,因此可以证明系统先将变量的值替换为“^>”然后再处理特殊符号“^”。 3、从变量替换上看 复制代码 代码如下: @echo off set ^&var=hero echo %&var% pause 结果:显示“hero” 这也说明变量的替换先于特殊符号的处理。 二、启动了变量延迟之后预处理又是如何进行呢? 我的看法是这样的:如果语句中存在英文叹号“!”则会被预处理两次,其它情况仍然是预处理一次。由于脱字字符比较特殊,因此在此借助该符号写几个例子说明一下。 (一) 复制代码 代码如下: @echo off echo !^^^^^> setlocal enabledelayedexpansion echo !^^^^^> pause 两个echo语句的结果不同。下面做一下分析: 对于第一个echo语句,变量延迟没有开启,进行预处理的时候该句就被预处理为“echo !^^>”,这也就是输出的结果。由此可见预处理只进行了一次。 对于第二个echo语句,此时变量延迟开启,由于有“!”存在,首先进行一次预处理得到“echo !^^>”,再进行一次得到“echo ^>”,结果也是如此。 之所以没有输出叹号,是因为开启了变量延迟,叹号就变为了特殊符号。 (二) 复制代码 代码如下: @echo off setlocal enabledelayedexpansion set var=hero echo !var! pause 像这里的“echo !var!”不是没有被预处理,而是被预处理了两次。看下面的这段代码就可以理解了。 复制代码 代码如下: @echo off setlocal enabledelayedexpansion set var=hero echo !var!^^^^^> pause 运行的结果为:“hero^>”。我们来分析一下,进行第一次预处理时,由于“!var!”,因此先不替换变量值而进行特殊符号的处理,处理完后就成了“echo !var!^^>”;之后再进行一次预处理, 此时就要替换“!var!”了,处理完后就成了“echo hero^>”。 (三) 我们再来看看当变量延迟开启时语句中不存在英文叹号的情况。 复制代码 代码如下: @echo off echo ^^^^^> setlocal enabledelayedexpansion echo ^^^^^> pause @echo off set var=hero echo %var%^^^^^> setlocal enabledelayedexpansion echo %var%^^^^^> pause 怎么样,也就是说如果没有“!”就不会进行第二次处理。 (四) 对于!!型,特殊符号的处理是在变量替换之前进行的。 例、 复制代码 代码如下: @echo off setlocal enabledelayedexpansion set ^&var=hero echo !&var! pause 这段代码运行结果是错误的。 例、 复制代码 代码如下: @echo off setlocal enabledelayedexpansion set var=^& echo !var! pause 这段代码运行结果是正确的。 (五) 既然都要处理符号,那么%%型和!!型的符号处理会不会是同一个过程? (一)中的例子已经可以说明问题,不过我还有例子可以证明。 例、 复制代码 代码如下: @echo off echo "^^^^^^^^"!! setlocal enabledelayedexpansion echo "^^^^^^^^"!! pause |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |