轉載自 nxhujiee最終編輯 LJ_SunTB批處理中的【預處理】
━━━━━━━━━━━━━━━━━━━━━━━━━━
如果你對脫字字符“^”的處理機制比較熟悉那么可以接著閱讀,否
則請先參考脫字字符的相關文章。
一、預處理究竟要做什么?
根據我的經驗,預處理要做的是變量值的替換和特殊符號的處理。究竟先執行哪個操作呢,我認為要先進行變量值的替換。理由有三:
1、 從邏輯上看
set var=2&echo %var%
類似于這樣的語句,如果說先進行特殊符號處理的話,勢必要先處理符號“&”,而“&”是用來連接兩條命令的,這樣一來該行就理所應當的被理解為兩句,那么我們還要變量延遲干嘛。這里應該是
先對變量var賦值,然后處理特殊符號“&”。
2、從運行結果看
代碼如下:
@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!^^>”;之后再進行一次預處理,
新聞熱點
疑難解答