标题: 『不知错在哪』关于goto :eof 嵌套的问题
[打印本页]
作者: lianniaodos
时间: 2008-6-30 17:38
标题: 『不知错在哪』关于goto :eof 嵌套的问题
我想用窗口显示比本地时间快一分钟的画面:
我的代码实现:
EnableDelayedExpansion&title 我把表表调快了一分钟耶~
@echo off
:a
set /a t=0 :: 测试标志
set a=%time:~0,2%
set b=%time:~3,1%
set c=%time:~4,1%
set /a d=%c%+1
if %c%==9 call:con9
set e=%b%%d%
if %t%==1 echo %a%:%e% T>>record00.txt ::test flag
cls
mode con:cols=33 lines=7
echo 调快一分钟的表,嘿嘿o( ̄▽ ̄)╯~
echo.
echo ################################
echo 现在时间是 %a% 点 %e% 分
echo ################################
ping -n 30 127.1>nul
goto a
:con9
if %b%==5 call:con5
set /a d=0
set /a b=%b%+1 goto :eof
:con5
set e=00
set /a a=%a%+1
echo 调快一分钟的表,嘿嘿o( ̄▽ ̄)╯~
echo.
echo ################################
echo 现在时间是 %a% 点 %e% 分
echo ################################
echo %a% 点 %e% 分 >>record00.txt
set /a t=1 :: 测试标志
goto :eof
可是程序运行时有错误:每当n点59分时,不是显示n+1点00分,而是n+2点60分
9点59分时ecord00.txt中显示
9 点 00 分
10 点 00 分
10:60 T ::test flag
9 点 00 分
10 点 00 分
10:60 T ::test flag
10 点 00 分
10:10 T ::test flag
10 点 00 分
10:10 T ::test flag
10 点 00 分
每当a点n9分时显示不显示a点(n+1)0分而是a+1点(n+1)0分
我感觉是我对goto :eof的理解有误,不过我不知到错在哪里
我用goto重写了一下程序,结果运行正常
可能是我把goto :eof 和call结合的理解错误,请高手释疑,
再者:goto: eof可以嵌套吗?
在就是EnableDelayedExpansion是不是在此程序中换成local,如果换成local是什么意思呢?