블로그 이미지
초딩입맛제주아재
하고 싶은 것만 하며 살고 싶다

calendar

1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
31
2007. 10. 28. 21:14 Programing/기타

이클립스에서 swing 예제를 만들다가 시스템이 느려지는 듯 하여 윈도우의 작업관리자를 띄워보니 javaw.exe 프로세스가 무려 100개가 넘게 떠있었다..-_-;
작업관리자에서 일일이 하나하나 프로세스를 클릭하여 죽여나가다 보니 슬슬 짜증이 밀려왔다.
100개가 넘는 프로세스를 언제 다 죽이남...리눅스처럼 한방에 죽이는 명령어 없나...
한참 고민하다가 웬지 kill 과 같은 명령어가 있을것 같아서 무작정 CMD를 열었다.

C:\Users\Administrator>kill
'kill'은(는) 내부 또는 외부 명령, 실행할 수 있는 프로그램, 또는
배치 파일이 아닙니다.


역시 안되는구나 -_-;;
근데 분명 다른 이름으로 존재하리란 믿음이 무럭무럭 솟아났다.
그러다 작업관리자의 프로세스 목록을 유심히 살펴보는데 작업관리자의 프로세스 이름이 taskmgr.exe 였다.
작업관리자가 taskmgr이라면 작업은 task라는 말이된다.
그렇다면 tasklist 라는 명령어가 있지는 않을까?

C:\Users\Administrator>tasklist/?

TASKLIST [/S 시스템 [/U 사용자 이름 [/P [암호]]]]
         [/M [모듈] | /SVC | /V] [/FI 필터] [/FO 형식] [/NH]

설명:
    이 도구는 로컬 또는 원격 시스템에서 현재
    실행되고 있는 프로세스 목록을 표시합니다.

크~ 있다있어~
tasklist 가 있으니 taskkill 도 있겠지~

C:\Users\Administrator>taskkill/?

TASKKILL [/S 시스템 [/U 사용자 이름 [/P [암호]]]]
         { [/FI 필터] [/PID 프로세스 id | /IM 이미지 이름] } [/T] [/F]

설명:
    이 도구는 프로세스 ID(PID) 또는 이미지 이름으로 작업을 종료하는 데
    사용합니다.

드디어 원하는걸 찾았다!
프로세스이름이 javaw.exe 인 모든 프로세스[/IM javaw.exe]를 강제종료[/F] 시켰다~

C:\Users\Administrator>taskkill /IM javaw.exe /F
성공: 프로세스 "javaw.exe"(PID 6788)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 6916)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 7076)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 6908)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 7208)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 7952)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 8140)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 8084)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 8356)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 8892)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 8540)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 9184)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 10976)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 10772)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 11316)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 11456)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 12072)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 12272)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 11416)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 11732)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 11940)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 11872)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 12720)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 12372)이(가) 종료되었습니다.
성공: 프로세스 "javaw.exe"(PID 12656)이(가) 종료되었습니다.
.
.
(이하 생략 ㅡ.ㅜ)

역시 윈도우도 제대로 쓰려면 공부를 해야 하나보다.
우리가 리눅스 공부를 밤을 세워 하는 것처럼...



 

posted by 초딩입맛제주아재
2007. 10. 21. 21:13 Programing/기타
개발환경: Eclipse WTP 2.0.1 all-in-one

개발환경 셋팅
1.Eclipse WTP 설치
http://www.eclipse.org/downloads/download.php?file=/webtools/downloads/drops/R2.0/R-2.0.1-20070926042742/wtp-all-in-one-sdk-R-2.0.1-20070926042742-win32.zip

2.XULBooster 설치
http://cms.xulbooster.org/index.php?option=com_frontpage&Itemid=1
설치방법: 위 주소에서 xulbooster를 다운로드 한 후 이클립스에서 help > software updates > find and install > search for new features to install > New Archived site... > 다운로드한 파일을 선택하여 Next~!

3.XULRunner 설치
http://releases.mozilla.org/pub/mozilla.org/xulrunner/releases/1.8.1.3/contrib/
OS에 맞는 버전을 다운로드 한 후 원하는 곳에 압축을 푼다.
콘솔로 해당 디렉토리에 가서 다음 명령을 실행한다.
xulrunner --register-global


XUL 기본 프레임워크

posted by 초딩입맛제주아재
2007. 6. 1. 11:09 Programing/기타

2.2 배치 파일을 돕는 실제적인 것들

2.2.1 영원한 숙제, COMMAND.COM의 이해

도스의 주인공이자 실질적인 관리자 역할을 하는 COMMAND.COM의 역할은

이미 많은 사용자들이 잘 알고 있을 것이다. 그러나 도스 프롬프트상태의 명령

행에서 입력되는 모든 명령들을 해석하고 이를 컴퓨터가 알아채도록 번역해 주

는 명령어 해석기로서의 COMMAND.COM의 구성에 대해 말만큼이나 올바로

알고 있는 분들이 적은 것 같다.

이는 몇 가지 매뉴얼에서 이에 대한 정확한 의미를 제대로 전달해 주지 못하

기 때문에 발생한 오해에서 비롯되는 것이므로 이번 기회에 COMMAND.COM

이 컴퓨터에서 행하는 역할을 다시 한번 정확히 짚어 볼 필요가 있을 것이다.

배치 파일뿐만 아니라 메모리 기저에 상주하는 COMMAND.COM의 상주 부분이 키보드로부터 입력되어 들어온 명령들의 해석상의 문제들을 어떻게

처리하는지 확인하는 것도 좋은 방법이 될 것이다.

보통 명령 해석기의 존재는 프로그램 실행 도중 도스쉘로 빠졌을 때의 실

제 처리를 담당하는 SECONDARY COMMAND PROCESSOR와 부팅과 함께

설치되는 도스 커맨드 행 상태의 ORDINARY COMMAND PROCESSOR로

구분할 수 있다.

처음 컴퓨터를 켰을 때 읽어 들인 COMMAND.COM은 일반적인 도스 프

롬프트 상태에서의 도스 명령어 해석기로 작동한다. 그러나 윈도우즈나 도

스의 도스쉘같은 응용 프로그램은 도스쉘로 빠졌을 때 도스 프롬프트를 출

력하기 위해 두 번재 COMMAND.COM을 읽어 들이게 된다. 이렇게 두 가지

이 명령 처리 쉘로 메모리에 상주된 부분이 있기 때문에 도스쉘로 빠져 나

왔을 때의 기본 메모리 사용량은 감소하게 되는 것이다.

이 두 번재 명령 처리기를 탈출하기 위해서는 도스의 내부 명령어인 EXIT

를 입력함으로써 첫 번째 명령 처리기로 제어권을 넘겨줘야 한다.

그럼, 도스 COMMAND.COM의 사용 방법은 어떠한지 구체적인 사용 옵션

과 실행 상의 차이점을 공부해 보도록 하자.

COMMAND[[drive:]path][device][/E:nnnnN][/Y[/C command|/K command]]

 

보통 배치 파일이나 명령행 상태에서는 위와 같은 구조를 가질 수 있지만

CONFIG.SYS 파일 안에서 지정할 경우에는 SHELL 명령 뒤에 적어 줘야 한

. 또한 배치 파일에서 루트 이외의 다른 디렉토리에 COMMAND.COM이

존재할 경우 이의 위치를 도스에게 알려주기 위해 COMSPEC 환경 변수를

사용하여 지정할 수 있다.

 

SHELL=[[dos-drive:]dos-path]COMMAND.COM [[drive:]path][device]

[/E:nnnn][/P [/MSG]]

명령행에서 사용될 때와 CONFIG.SYS에서 사용될 때의 사용 옵션과 스위

치가 다른 것을 알 수 있다. 이는 실행 명령으로서 존재하는 배치 파일과

디바이스나 드라이버의 설치를 위한 CONFIG.SYS 파일의 양쪽 특성을 모두

처리해야 하는 COMMAND.COM의 명령 해석기로서의 특징 때문이다. 그럼

각 파라메터와 스위치에 대한 설명은 다음과 같다.

▶ [drive:]path

도스가 COMMAND.COM의 일부분을 다시 읽어 들일 때, 명령 해석기의

위치를 찾을 수 있는 드라이브와 디렉토리 경로를 지정한다.

▶ drive

CITY 명령을 이용하여 명령의 입력과 출력을 위한 다른 디바이스를 지정

할 수 있다. 기본적으로 현재 사용중인 장치가 계속 사용된다.

▶ /C command

앞의 CALL 명령에서 잠간 설명했듯이 두 번째 명령 해석기를 읽어 들여

command에 지정된 명령을 실행하고 다시 exit로 빠져 제어권을 첫 번째 명령

해석기로 돌려주는 기능을 한다. 이 스위치는 명령행의 마지막에 위치해야

한다.

▶ /E:nnnnn

명령 해석기를 위한 환경 크기를 설정하는 옵션이다. 단위는 바이트로 이

루어지며, 지정 가능한 값의 범위는 160부터 32768까지의 값이 사용된다. 아

무런 값이 지정되지 않으면 디폴트로 256이 사용된다.

▶ /K command

/k 스위치는 다음에 지정된 명령을 실행한다. 이 옵션은 도스 6.0부터 지원

되기 시작했으며, /c 스위치와 마찬가지로 명령행의 마지막에 위치해야 한다.

이 스위치는 윈도우즈에서 MS-DOS 프롬프트를 위한 STARTUP 배치 파일

을 지정하는데 특히 유용하며, 그렇게 하기 위해서는 pif 에디터에서 DOSPRMPT.PIF 파일을 열고 Optional Parameters 박스에 /K 스위치를 적어

줘야 한다. 그러나 이 /k 스위치를 config.sys의 shell행에 이용하지 않는 것이

좋다. 왜냐하면 사용자의 autoexec.bat 파일을 변형시키는 일부 응용 프로그램

과 인스톨 프로그램과 문제를 일으킬 소지가 많기 때문이다.

▶ /P

CONFIG.SYS의 SHELL 명령과 함께 사용되는 옵션이다. 이 스위치는 명령

어 해석기인 COMMAND.COM의 새로운 복사본을 항상 만들게 하여 메모리

에 이 상주 부분이 존재하도록 하는 역할을 한다.

▶ /MSG

이 스위치는 플로피 디스크로부터 MS-DOS를 실행하려고 할 때 유용하며,

/P 스위치와 함께 사용되야 한다.

▶ /Y

이 스위치는 /C나 /K 스위치에 의해 명시된 배치 파일을 한 줄씩 순차적

으로 진행하도록 COMMAND.COM에게 지시한다. 대개 이것은 배치 파일을

디버깅할 때 매우 유용하다.

2.2.2 COMMAND.COM의 환경 구성

도스 명령어 해석기인 COMMAND.COM의 환경은 처음 부팅할 때 구축된 다. 즉 사용자가 새로운 COMMAND.COM을 실행시켰을 때, 도스는 새로운 명

령어 처리 환경을 생성하게 된다는 뜻이다. 그리고 옵션 지정 없이 시작된 새

로운 환경은 기존에 메모리에 상주하고 있던 명령 환경을 복사하여 사용하게

된다. 이때 원래 환경에 영향을 미치지 않고 새로 시작한 COMMAND.COM의

환경을 바꿀 수 있는데 기본값으로는 256bytes가 할당된다.

도스가 명령어 해석기인 COMMAND.COM을 메모리로 불러들일 때 두 가

지 부분으로 나누어 불러들이게 된다. 메모리에 항상 상주하게 될 상주

(RETURN) 부분과 기본 메모리의 위 영역에 필요시마다 일시적으로 머무

TRANSIENT 부분으로 존재하는 COMMAND.COM은 다른 프로그램이

TRANSIENT 부분에 겹쳐 써질 경우 디스크로부터 다시 로딩해야 한다. 이

때 필요한 것이 환경 변수 COMSPEC의 지정 여부이다. 일단 COMSPEC을

통해 COMMAND.COM의 위치를 알고 있다면 지정된 디스크 드라이브에서

COMMAND.COM을 찾게 된다.

또한 DOS=HIGH 명령에 의해 도스 상주부가 HMA(High Memory Area)에

로딩되었다면, 기본 메모리를 차지하고 있던 COMMAND.COM의 상주 영역

이 빠지므로 이용할 수 있는 메모리의 양이 늘어나게 된다. 대개 도스는 에

러 메시지에 관한 내용을 메모리에 저장해 두지 않고 디스크에 존재하는

COMMAND.COM 파일 안에 남겨 두게 되는데, 도스가 에러 상황을 만났을

때마다 필요한 메시지를 디스크로부터 찾아서 화면에 보여주게 된다.

만약 하드 디스크 대신 플로피디스크로부터 부팅하였다면 도스는 드라이브

A로부터 COMMAND.COM을 찾아 에러 메시지를 보여주려 할 것이다. 이때 A

드라이브에 들어 있는 디스켓에 COMMAND.COM이 포함되더 있지 않다면, 도

스는 에러에 적절하고 완전한 메시지를 표시하지 못한다. 그런 경우를 대비해

COMMAND.COM의 /MSD 스위치는 디스크에 저장되어 있는 에러 메시지를

메모리에 상주시켜 완전한 에러 메시지를 보여주게 하는 것이다.

2.2.3 도스 환경의 조율사 SET

SET 명령은 MS-DOS 환경 변수를 화면에 보여주거나 지정하고 제거하는데

이용되는 명령이다. 배치 파일이나 프로그램이 도스 상태에서 적절히 적절한

환경으로 설정되었는지를 나타내거나 제어하는데도 이 SET 명령이 사용되며,

도스를 시작할 때마다 환경 변수를 조정하기 위해서는 AUTOEXEC.BAT나

CONFIG.SYS에 직접 SET VARIABLE=[STRING]과 같은 형식을 통해 지정해

줘야 한다.

도스 프롬프트에서 현재 지정된 환경 변수들을 알아보기 위해서는 그냥SET 이라고 입력하면 설정된 모든 환경 변수와 환경 영역에 기록된 모든 내용을

보여준다. 이 환경변수는 프로그램 사용중이나 배치 파일 실행에 있어서 매우

중요한 요소로 사용될 수 있다.

일반적으로 이름 변수명과 문자열을 연결 지어 환경 영역에 지정해 주기

위해서는 다음과 같이 SET 명령을 이용한다. 예를 들어 노턴 유틸리티 디렉

토리인 C:NORTON을 SYMENTEC이란 이름 변수에 연결 지었다면, 배치 파

일에서 노턴 디렉토리를 % 기호로 둘러친 이름 변수로 표현할 수 있게 된다

다시 말하자면 앞서 SYMENTEC이란 이름 변수에 연결된 C:NORTON이란

디렉토리를 직접 대입 변수명으로 사용할 수 있다는 것이다.

dir %SYMENTEC%

 

이와 비슷하게 SET 명령은 배치 파일에서 또 다른 사용 방법이 있다. 바로

PATH 환경 변수에 새로운 디렉토리를 지정하거나 추가할 때도 이용될 수 있

. 다음의 배치 파일 예제에서 볼 수 있듯이 기존의 %PATH% 변수에 대체 변수 %1이 추가되는 새로운 패스 환경을 만드는 SET PATH = 명령을 사용 하였다.

 

@echo off

rem PATH_ADD.BAT adds anew directory to the PATH environment variable.

set path=%1, %path%

set

<예제 2-14> set문을 이용한 배치 파일

기본적으로 SET 명령을 통하지 않고도 도스는 3가지의 환경 변수를 설정

하게 된다. 경로명을 설정하는 PATH, 명령 대기 상태를 나타내는 PROMPT

그리고 명령 처리기의 선택을 가리키는 CONFIG가 그것이다. 또한 환경 변

수는 변수명에 입력된 모든 문자를 대문자로 기억하게 된다. 실제로 대소문

자 구분이 있는 것은 아니지만 변수명에 치환된 문자열이 대입되는 것을 보

면 쉽게 알 수 있을 것이다.

그리고 IF 명령에서 환경 변수를 사용할 때에는, 널(NULL)값이 사용되는

경우를 대비해서 따옴표로 둘러쳐서 표현해야 할 필요가 있다. 보통은 환경

변수나 문자열에 따옴표를 사용하면 이것까지 환경 영역에 저장되어 표현되

므로 주의해야 한다.

그럼, 사용자의 컴퓨터의 환경 영역을 조회하기 위해서 어떻게 해야 하는

? 그것은 도스 프롬프트에서 SET라고 입력하고 엔터를 치면 현재 설정된

모든 환경 변수의 내용을 보여준다.

C:>SET

CONFIG=4DOS

PATH=C:SYSDOS;C:;C:qemm;C:SYS4DOS;E:HWP25;C:U1;C:U1EQ;

C:U1A;C:U1V;C:U2NT;

LOADHIDATA=C:QEMMLOADHI.RF

COMSPEC=c:sys4dos4dos.com

ARJ_SW= -JYRY -JV -I1 -JM1

TEMP4DOS=f:

TMP=f:

TEMP=F:

PKTMP=f:

.LZH=C:U1ALHA.EXE E

.ARJ=C:U1AARJ.EXE E

.ZIP=C:U1APKUNZIP

.OMP=C:U1AOMP.EXE E

.SQZ=C:U1ASQZ.EXE E

.DOC=C:U1MDS.EXE

.TXT=C:U1MDS.EXE

.HWP=d:hwp25hwp.exe

PROMPT=Type EXIT to return to hwp$_$p$g

SYMANTEC=C:U2NT

PCTOOLS=D:PCTOOLSDATA

HWPSTUB=SWAPDIR E:HNCTEMP -SWAPNAME HWP25.SWP

<SET 명령으로 설정된 환경 변수의 목록>

이제 환경 변수에 대해 어느 정도 이해가 가셨으리라 믿는다. 다음 장은

실제적으로 시스템을 구성하는 autoexec.bat 파일과 config.sys에 대해서 자세

히 살펴볼 것이다. 자신의 컴퓨터를 가지고서도 배치 파일과 config.sys 파일

구성에 어려움을 겪거나 두려움을 가진 분들은 꼭 한번 봐야 할 것이다. 가

장 기본적인 내용이면서도 선뜻 시스템을 망가뜨리지 않을까 겁먹고 계신

분들에게 좋은 해결책이 될 것이다.

윈도우즈의 문제를 해결하는 방법.

윈도우즈를 실행하다 보면 메모리 문제, 디바이스 설치에 관한 문제, INI 파일 설정에

관한 문제와 같은 다양한 문제에 골치를 섞이게 된다. 이런 문제를 도스에서는 직접

AUTOEXEC.BAT나 CONFIG.SYS 파일을 조작하거나 수정함으로써 해결할 수 있지만,

윈도우즈는 복잡한 구성 때문인지 몰라도 만만한 해결책이 없을 것이다.

윈도우즈는 기본적으로 실행 옵션을 여러 개 사용할 수 있는데, 여기서 디버그 모드로

윈도우즈를 실행하면서 충돌이 발생하는 부분을 찾아낼 수 있다.

윈도우즈는 디버그 모드로 실행시킬 때 4가지 옵션을 제공하며, WIN /?를 치면 옵션의

설명이 자세히 나온다. 그럼 4가지 옵션을 주고 디버그 모드로 실행시키는 방법을 알아보자.

① WIN /D:X

이 옵션을 주는 이유는 사용자가 판단하게 메모리 충돌이나 디바이스 램상주 프로그램

이 상위 메모리에 상주했을 때 윈도우즈와 충돌을 일으킬 경우 이를 해결하기 위해 사

용하는 것이다.

② WIN /D:F

이 옵션은 윈도우즈의 386확장 모드 실행시 조정되는 32비트 디스크 엑세스 옵션과

관계된 문제를 해결하는 것이다. 옵션 F는 32비트 디스크 엑세스 방식으로 하드 디

스크에 접근하는 것을 방지하고 표준 바이오스 방식을 통해 하드 디스크에 접근하게

하는 옵션이다.

③ WIN /D:V

V 옵션은 하드 디스크를 가상 메모리로 사용하지 못하게 하는 옵션이다. 스카시 드라

이브를 가지고 있는 경우 이 옵션이 충돌을 해결하는데 중요하다.

④ WIN /D:S

이 옵션 명령은 상위 메모리의 F000에서 FFFF까지의 영역에 존재하는 롬바이오스

부분에서 SYSTEM BREAK POINT라는 지시행을 찾지 못하도록 하는 것이다.



기본적으로 이런 실행 모드 조정을 통해 문제를 발견할 수 있지만, 더욱 세부적인 사

항을 알아내지 못할 경우에는 윈도우즈 실행시 어딘가 문제가 있을 때이다.

윈도우즈 디렉토리에 부트 로그 파일을 만들기 위해서는 윈도우즈를 실행할 때 /B옵

션을 줘서 실행해야 한다. 그러면 윈도우즈가 설치될 때, 메모리에 띄워지는 모든 프

로그램과 파일에 대한 기록을 하게 된다. 여기서 이 로딩기록을 적어 둔 파일을 분석

해 봄으로써 문제의 원인을 찾아낼 수 있다.

이 방법은 INI 파일에 기록된 실행 순서에 맞지 않는 프로그램이나 폰트, 데이터 파일

등이 로딩되는데 실패하는가의 여부를 파악하기 쉽다. 이 같은 사실을 알아내는데는

에러 코드를 로그 파일에 기록하기 때문이다. 에러 코드에 관한 내용은 다음과 같다.

⊙ 윈도우즈의 에러 발생시 각 코드 번호가 의미하는 것

0 : 메모리가 부족한 경우이다.

2 : 지정된 파일이 해당 디렉토리에 없는 경우

3 : 패스가 지정되어 있지 않는 경우, 기존에 있던 디렉토리를 지운 경우에 발생한다

5 : 파일 확장자나 데이터를 작업이나 프로그램에 동작으로 연결하려다 실패한 경우이다.

6 : 라이브러리에서 각 작업에 대해 분리된 데이터 세그먼트를 요구하는 경우

8 : 응용 프로그램을 실행하기 위한 메모리가 부족하다.

10 : 구버전의 윈도우즈 파일을 가져온 경우이다.

11 : EXE 파일이 손상된 경우이거나 윈도우주용 프로그램이 아닌 경우이다.

12 : OS/2전용 응용 프로그램을 윈도우즈에서 실행하려는 경우에 발생한다.

13 : MS-DOS 4.0과 OS/2 1.0에서 실행할 수 있는 패밀리 모드 프로그램을 실행

하려는 경우이다.

14 : EXE 파일이 손상되어 있다.

15 : 보호 모드에서 예전에 만들어 호환되지 않는 윈도우즈 실행 파일을 실행하려는 경우

16 : 여러 개의 데이터 세그먼트가 들어 있는 EXE 파일의 복제본을 띄우려 하는 경우

17 : 대형 프레임에서 EMS모드로 이미 사용 중인 DLL을 응용 프로그램과 연결하려는 경우

18 : 보호 모드용 프로그램을 리얼 모드로 실행하려는 경우에 발생한다.

참고사항 : 도서출판 (혜지원), 저자(오요한), book title(배치와 매크로)

posted by 초딩입맛제주아재
2007. 6. 1. 11:07 Programing/기타

배치 파일과 도스 명령어

 

도스 상태에서 지원되는 기본적인 배치 명령어들에 대해서 살펴보도록 하자. 이들 기본 명령어만 잘익히고 활용해도 좀 더 편리한 환경을 만들 수 있을 것이다. 또한 이는 작업을 빠르게 하는 방법을 찾을 수 있는 최초의 길이 될 것이다.

 

도스의 배치 파일에서 주로 사용되는 명령들은 모두 합쳐 수십 개 이상이지만 주로 사용되는 명령들에 대해 살펴보는 것만으로 다른 명령에 대한 이 해를 높일 수 있다. 명령들은 단지 집을 짓는 도구에 지나지 않는다.각각의 도구를 잘 이용하여 훌륭한 집을 짓기 위해서는 모든 도구를 잘 갈아야 하며, 부러지지 않도록 튼튼하게 손을 봐야 할 것이다. 배치 프로그래밍도 마찬가지다. 하나씩 정확한 개념을 이해함으로써 커다란 집을 지어 나갈 수 있을 것이다. 자! 그럼 같이 집을 지어 봅시다.

 

2.1 핵심 배치 파일 명령어들
도스의 배치 파일에서 사용되는 명령어는 도스 프롬프트에서 실행 가능한

모든 명령어들이 포함된다. 그러나 배치 파일에서만 전용으로 사용되는 명

령어들이 따로 존재하는데, 이러한 명령들의 형식과 사용법을 익혀 두는 게

배치 파일에 접근하기 위한 가장 우선적인 방법이다.

그럼 먼저 주요 배치 명령의 형식과 기능에 대해 설명하고 예를 들어 살

펴보자.

 

2.1.1 ECHO

ECHO는 배치 파일 안에 있는 명령이 실행될 때 명령어의 이름을 보여주

거나 감추어 주는 기능을 한다. 즉 명령 반항(ECHO) 상태를 설정하거나 취

소하기 위해 사용되는 명령이다. 마치 토글(TOGGLE)키처럼 동작하기 때문

에 처리 과정을 화면에 표시 여부를 쉽게 조정하게 된다.

* 형식 : ECHO ON or ECHO OFF



배치 파일에서 ECHO OFF로 지정되었을 때에는 명령어 이름을 보여주지

않고 실행함으로써 사용자가 혼동될 가능성이 있는 반면 화면이 지저분하지

않게 해준다. ECHO의 기본값은 ECHO ON으로 설정되어 있다. 따라서 도스

는 배치 파일이 실행이 끝나면 다시 ECHO ON으로 리셋(RESET)시키게 되

는데, 도스 3.3 이후부터는 ECHO OFF 자체도 앞에 @ 표시와 함께 써 줌으

로써 ECHO OFF가 화면에 표시되는 것을 막을 수 있게 되었다.

2.1.2 REM

배치 파일 내의 실행중인 명령과 기능 등을 사용자가 이해하기 쉽도록 주

석을 달 수 있게 해준다.

* 형식 : REM [설명문]

 

이 주석은 배치 파일이 길어진다던가 복잡해질 경우 프로그램의 이해를

높이기 위해 달아 주는 것이 좋다. 프로그래밍을 해보신 분들은 아시겠지만

소스를 보기 위해 얼마나 눈이 아프게 왔다갔다하십니까? 프로그램 분석시

이해하기 쉽게 하기 위해서 다음과 같이 한 줄 정도를 중간 중간에 띄어쓰

는 것도 좋은 방법이다. 이때 아무 기능을 하지 않는 빈줄 삽입을 위해 REM을 사용할 수 있다.

일반적으로 REM 명령은 배치 파일 작성자와 작성 날짜, 사용 목적 등을

기술하는데 사용하게 되며, 동작 과정을 이해하기 쉽게 주석을 이용하여 보

조 설명을 달거나 옵션과 도움말 설명을 위해 사용하기도 한다.

또 이 REM 명령이 사용되는 경우는 배치 파일 내의 명령어 중에서 일시

적으로 실행을 중시하려는 명령이 있을 때 사용되기도 한다. 즉 이 명령을

명령어 앞에 적어 두면 도스가 주석문으로 인식하기 때문에 실행이 되지 않

는다. 그리고 작성된 배치 파일이 원하는 대로 실행되지 않는다면, 명령어

앞에 REM을 추가하여 해당 명령어를 실행시키지 않은 상태로 만들어 놓고

문제가 발생한 행을 찾아낼 수 있다.

ECHO OFF

REM NAME REM_TEST.BAT

REM FUNCTION: REM 명령의 사용 예를 보여주기 위한 배치 파일이다.

REM 아래 rem 명령의 3가지 사용 예를 보여주었다.

REM (기능 1) 설명을 위해 사용한다.

REM 이렇게 설명을 달 수 있다.

REM (기능 2) 분석시 기독성을 위해 빈줄을 위해 삽입할 때 사용할 수 있다.

REM

REM (기능 3) 실행 명령어의 중지를 위해 사용한다.

REM CHKDSK

<예제 2-1> REM 명령을 이용한 배치 파일

2.1.3 PAUSE

처리중인 배치 파일을 멈추고 사용자에게 조건적인 메시지를 보여준다.

사용자가 어떤 키를 눌렀을 때 계속해서 처리된다. 이 명령은 배치 파일을

일시 중단시키는 기능을 하는데 지나가 버리는 화면을 사용자가 읽기 편하

게 잡아 놓기 위해 사용되거나 다른 준비 작업을 위해 약간의 여유를 주기

위해 이용된다.

* 형식 : PAUSE [message]

 

배치 파일 실행중에 PAUSE 명령을 만나게 되면, 도스는 "Press any key

to continue ..."와 같은 메시지를 화면에 보여준다. 또한 이 PAUSE 명령은

배치 작업 계속 실행 여부를 판단하기 위해 적합하다. 즉 배치 파일의 연속

적인 실행 과정 내에 이 PAUSE 명령을 삽입해 둠으로써 CTRL+C를 이용한

실행 중단을 쉽게 할 수 있다.

@echo off

echo please put a new disk into drive B

pause

copy a:*.* b:

<예제 2-2> PAUSE 명령을 이용한 배치 파일

위의 예제는 A 드라이브의 모든 파일을 B 드라이브로 복사하기 전에 디

스켓을 B 드라이브에 집어넣으라는 대기 시간을 제공하기 위해 PAUSE 명

령을 사용하였다. 이처럼 준비 작업을 위한 시간을 주기 위해서나 아니면

사용자의 판단을 돕기 위해 사용된다.

2.1.4 IF

배치 파일의 조건적인 처리를 수행하도록 하는 명령어이다. IF 문에 투입

된 내용의 값이 조건을 만족하는 '참'(TRUE)이면, IF 문 다음의 문장을 수행

한다. 그러나 조건의 값이 거직(FALSE)이면 뒤따라오는 문장의 명령을 무시

하고 넘어간다. 일반적인 IF문의 종류로는 6가지의 독특한 조건이 허용된다.

1) IF EXIT filename.ext(or parameter) Command

2) IF NOT EXIT filename.ext(or parameter) Cmmand

3) IF String1== String2 Command

4) IF NOT String1==String2 Command

5) IF ERRORLEVEL value Command

6) IF NOT ERRORLEVEL value Command

여기서 잠시 도스 배치 파일에서 사용되는 파라메터(변수)에 대해 알아보

. 도스 배치에서 사용되는 파라메터(변수)는 %0 %1 %2 %3 %4 %5 %6

%7 %8 %9와 같은 10개가 있다. 그리고 프롬프트 상태에서 맨 앞에 오게

되는 도스 명령어는 대개 변수 %0에 배당된다.

 

C:>COPY PARA1.TXT PARA2.TXT

│ │ │

%0 %1 %2

 

♣ IF EXIST 형식

IF EXIST는 IF 문에서 가장 간단한 형식이다. 조건에 해당하는 파일이나 변

수에 입력된 값이 존재하면 뒤에 따라오는 명령을 수행한다. 즉, 조건의 값이

참이면 다음 문장을 수행하는 구조이다. 다음의 예를 보면 쉽게 이해될 것이다.

IF EXIST C:IF_ONE.TXT PRINT C:IF_ONE.BAT

위 문장은 C 드라이브의 루트 디렉토리에 IF_ONE.TXT 파일이 존재하면

프린트하라는 뜻이다. 이처럼 배치에 사용되는 문장은 일반 영어 문장의 의

미를 그대로 포용하고 있기 때문에 간단한 영어 단어 지식만 있으면 의미를

파악할 수 있다. 다른 예를 보도록 하자. MYCOPY.BAT라는 배치 파일을 다

음과 같이 만들었다고 하자.(이 예제는 앞에서 살짝 다룬 변수를 이용하였다)

rem 이 배치 파일의 이름은 MYCOPY이다.

IF EXIST %2 PAUSE Target file already exists

copy %1 %2

<예제 2-3> If Exist 형식이 사용된 간단한 배치

MYCOPY.BAT를 실행시키기 위해 도스 프롬프트에서 다음과 같이 입

력했는데 정상적으로 실행되지 않는다면 BOSS.TXT라는 파일이 디스크에 존

재하지 않아 IF문의 조건문이 거짓이 되기 때문이다. 하지만 두 파일이 모두

존재하여 조건을 참으로 만든다면 IAM.TXT라는 파일을 BOSS.TXT에 정상

적으로 복사할 것이다.

MYCOPY IAM.TXT BOSS.TXT

♣ IF NOT EXIST 형식

IF NOT EXIST 조건은 원하는 파일이나 대입된 변수의 값이 존재하지 않

아야 지정된 명령을 처리한다. 앞에서 다룬 IF EXIST문과 정 반대의 의미로

사용된다. 이 형식은 배치 파일 구성상 실행에 관계된 중요한 파일이 존재

하지 않을 경우 지정된 행으로 이동하여 배치 프로그램의 실행을 중단하도

록 하는데 많이 이용된다.

IF NOT EXIST %1 ECHO %1 Does Not Exist in Your disk

 

앞 예제 문장은 변수 %1이 존재하지 않아야만 조건값이 참이 되어 뒤에

따라오는 명령을 수행하게 된다. 이것은 NOT이라는 부정 조건이 추가되었

기 때문에 존재하지 않아야만 참이 되는 것이다.

♣ IF String1==String2 Command 형식

이 조건은 문자열이나 문자 하나를 변수로 입력받으면 배치 파일 내에 미

리 지정된 문자열과 비교하고 같으면 다음 명령을 처리하게 된다. 그리고

비교되는 두 문자열이 일치하지 않는다면 다음 행으로 건너뛰게 되는 구조

이다. 보기로 QUESTION.BAT란 간단한 파일을 만들어 보자

REM 이 배치 파일의 이름은 QUESTION.BAT이다.

ECHO OFF

IF %1==BOSS ECHO YOU ARE A BOSS...1

IF %1==HERO ECHO ARE YOU A HERO...?

IF %1==FOX ECHO IS SHE A FOXY...?

<예제 2-4> If string문을 이용한 배치 파일

위와 같이 조건을 만들었다면, 다음과 같이 입력해 보자. 해당되는 메시지

가 있을 경우는 ECHO 명령 다음에 기록된 메시지를 보여주게 된다.

C:>QUESTION BOSS

YOU ARE A BOSS...!

그러나 여기서 BOSS라는 변수를 주지 않으면 어떻게 될까? MS-DOS에서

Syntax error를 표시하고 에러 처리된다. 그러나 4도스라는 도스쉘을 사용

할 경우에는 이럴 때 배치 파일의 맨 첫머리에 있는 ECHO OFF만 화면에

표시하고 만다. 왜냐하면 %1에 들어올 비교 변수가 없기 때문이다. 다시 말

하자면 지정된 변수와 비교할 대상이 없기 때문에 첫 명령만 실행되고 마는

것이다. 하지만 위의 조건문 다음에 또 어떤 명령이 있었다면 변수가 없더

라도 조건문 다음에 오는 다른 명령들을 실행할 것이다.

특히 주의해야 할 점은 이들 문자열 비교시 대·소문자를 구분한다는 것

이다. 비교 대상열을 소문자로 적어 두고 변수명에 대문자로 같은 이름을

사용하면 조건 비교시 같은 변수로 판단하지 않는다는 것이다.

++ 이 문제를 해결하기 위해서는 두 문자열을 " " 로 둘러쳐 주면 사용자

가 실수로 변수를 입력치 않아도 에러 메시지를 내지 않는다. 이유는 인용

부호는 빈 문자열(EMPTY)을 생성해 주기 때문이다.

IF "%1"=="BOSS" ECHO YOU ARE A BOSS...!

IF "%1"=="HERO" ECHO ARE YOU A HERO...?

IF "%1"=="FOX" ECHO IS SHE A FOXY...?

 

위와 같이 해주면 에러 메시지가 나오지 않게 된다.

♣ IF NOT String1==String2 Command 형식

변수로 주어지는 문자열이 같지 않아야만 조건 뒤에 오는 명령을 실행한

. 이 형식 역시 NOT라는 부정 조건자를 포함하고 있기 때문에 비교되는

두 변수가 일치하지 않아야만 참이 되어 연속되는 명령을 실행하게 되는것

이다.

ECHO OFF

IF NOT "%1"=="%2" COPY %1 %2

<예제 2-5> If NOT문을 이용한 배치 예제

예제에서 알 수 있듯이 두 변수가 같지 않다면 뒤에 따라오는 COPY 명

령을 수행한다. 그러나 두 변수가 같을 경우에는 거짓이 되어 계속되는 명

령을 수행하지 않는다. IF String1==String2와 IF NOT String1==String2 문장

은 서로 보완적으로 배치 파일에서 사용되어 특정 문자나 변수를 비교하는

데 이용된다.

♣ IF ERRORLEVEL value Command 형식

탈출 상태 코드(EXIT STATE VALUE)가 주어진 값보다 크거나 같으면 지

정된 도스 명령을 실행한다.

예를 들어 도스의 외부 명령어인 FORMAT.COM의 EXIT STATE VALUE

가 다음과 같다고 할 때, IF ERRORLEVEL 문의 처리 방법은 다음 예제와

같다.

VALUE

에러 레벨 처리 내용

0

포맷 성공

3

CTRL+C가 눌려져 포맷이 중단된 경우

4

디스크 에러에 의해 포맷이 실패한 경우

5

프롬프트에서 사용자가 중단한 경우




<표 2-3> FORMAT.COM의 탈출 코드값과 설명

REM 이 예제는 FORMAT 명령어의 에러 탈출 코드를 이용한 배치 파일이다.

ECHO OFF

FORMAT A:

IF ERRORLEVEL 5 GOTO NO_RESPONSE

IF ERRORLEVEL 4 GOTO ERROR

IF ERRORLEVEL 3 GOTO USER_CTRLC

ECHO SUCCESSFUL FORMAT OPERATION

GOTO DONE

:NO_RESPONE

ECHO FIXED DISK WILL NOT BE FORMATTED

GOTO DONE

:ERROR

ECHO ERROR IN PROCESSING, FORMAT FAILED

GOTO DONE

:USER_CTRLC

ECHO FORMAT FAILED DUE TO CTRL-C BY USER

:DONE

 

<표 2-6> If Errorlevel문을 이용한 배치 파일

이 배치 파일로 포맷하던 중 디스크 에러가 나거나 컨트롤-C를 눌러 중지

됐다면 에러 레벨 코드와 루프 탈출 상태 값을 비교하여 맞는 레이블로 이

동한 다음에 적합한 에러 메시지를 보여주는 프로그램이다. 즉, 에러 레벨

처리 조건문은 값을 에러 레벨 코드와 비교하여 크거나 같으면 지정된 명령

을 실행하게 된다.

♣ IF NOT ERRORLEVEL VALUE COMMAND

이 조건은 "IF Errorlevel Value 명령 형식"과 반대로 생각하면 된다. 실제

에러 레벨 값과 지정된 값이 같지 않아야만 다음 명령을 처리한다.

 

ECHO OFF

FORMAT A: /S

IF NOT ERRORLEVEL 3 GOTO END

ECHO AN ERROR OCCURRED DURING FORMATING.

:END

ECHO END OF BATCH PROGRAM

<표 2-7> If Not Errorlevel문을 이용한 배치 파일

위의 예제는 A 드라이브에서 디스켓을 포맷하던 중 CTRL+C를 눌러 에러가

발생하면, 에러 레벨 코드가 같아지기 때문에 AN ERROR OCCURRED DURING

FORMATTING라는 에러 메시지를 표시하고 중단된다. 하지만 에러 레벨 코드 3

번이 아닌 경우에는 값이 참이 되어 에러 메시지를 보여주지 않게 된다.

2.1.5 FOR

FOR문 역시 일종의 반복 조건문으로 주어진 조건을 만족할 때까지 도스

명령어를 실행한다.

* 형식 : FOR %%변수명 IN (SET) DO Command

 

앞의 형식만 보고 어떻게 적용해야 하는지 이해가 잘 안될 것이므로 보기

를 보는 게 좋을 것이다. 위의 퍼센트 기호 두 개와 함께 쓰인 변수는 앞에

서 다뤘던 숫자 변수와 달리 '이름을 가진 변수' (NAMED VARIABLE)이다.

이 때문에 숫자 변수와 구분하기 위해 이름 변수는 앞에 %(퍼센트 기호)를

두 개 붙여 준다.

그리고 FOR 다음의 변수명으로는 한 문자로된 알파벳만을 사용할 수 있

. 또한 괄호 안의 (SET)은 범위를 알려주는 것으로 *(ASTERISK)나 파일들

의 이름을 스페이스(SPACE)나 COMMA(,)로 구분하여 적어 줘도 된다. 이와

같이 특정 조건을 주기 위한 괄호 안의 마스크(MASK)로는 다음과 같이 적

용할 수 있다.

(*.*) (BOOK1.BAT BOOK2.SYS BOOK3.COM) (*.BAT)...

그럼 다음의 간단한 예를 통해 반복적인 조건을 탐색해 내는 FOR문의

예제를 살펴보도록 하자.

FOR %%I IN (*.BAT) DO TYPE %%I

위의 문장은 현재 디렉토리의 모든 *.BAT 파일 중에서 변수로 대입되는

파일을 찾아 TYPE 명령으로 보여줄 것이다. 그런데 이 문장을 도스 프롬프

트의 명령행 라인에서 직접 사용하기 위해서는 변수명 앞에 %(퍼센트 기호)

를 하나만 써야 한다.

FOR %변수명 IN(set) DO command [command-parameters]

 

♣ 변수명 사용시 주의 사항

변수명에 사용되는 문자는 앞에서 알파벳 문자 하나만을 사용할 수 있다

고 했다. 그것은 배치 프로그램에서 사용되는 %0∼%9까지의 숫자 변수들과

혼란을 피하기 위해서이다. 그리고 복잡한 배치 파일에서처럼 다른 대체 변

수와 구분할 필요가 있는데 이때 여러 개의 입력 값을 위한 다른 변수 명을

사용할 수 있다. 그러나 한 줄의 같은 명령행에서 포함 관계에 있는 여러

개의 FOR문을 사용할 수는 없다.

또한 FOR문에는 도스에서 사용되는 명령 스위치나 파이프, 리디렉션 등

을 지원한다.

FOR %f in(*.doc *.txt) do type %f > pm

2.1.6 GOTO

조건에서 만족하면 지정된 레이블로 제어를 옮겨 주는 기능을 한다. 레이

블명은 :(COLON)을 앞세우고 적는다. 이 GOTO 명령은 배치 프로그램 안에

서만 사용되는 명령으로 도스 명령어 처리기에게 지정된 레이블명이 있는

행으로 제어권을 이동하게 한다. 일단 제어권이 이동한 다음에는 연속해서

그 다음 행의 명령들을 처리한다.

GOTO label

 

GOTO 명령에서 유효한 레이블명은 공백(SPACE)이나 ;(세미콜론),

=(EQUAL)과 같은 기호를 포함하지 않아야 하며, 8자를 넘지 않는 게 좋다.

이는 GOTO 명령이 레이블명에 사용된 문자 중 첫 8자까지 만을 인식하기

때문이다. 마치 도스에서 파일명이 8자인 것과 같은 구조로 인식하기 때문

이다. 그것을 증명하기 위해 "THIS_IS_1"과 "THIS_IS_2"란 레이블명이 배치

파일 안에 존재한다고 할 때 GOTO문이 지정한 이들 레이블명은 "THIS_IS_"

와 같이 앞에서 8자까지 만을 인식하게 된다. 따라서 두 개의 레이블명은 같

은 레이블명으로 인식하게 되어 먼저 나타난 쪽으로 제어권을 이동하게 된

. 이런 점은 GOTO문 사용시 주의해야 할 것이다.

다음 예제는 IF NOT ERRORLEVEL문과 함께 쓰여 디스크 포맷시 발생한

에러 레벨 값이 1이 아니면 GOTO문에 의해 END레이블로 제어권이 이동하

게 되는 구조이다.

echo off

format a: /s

if not errorlevel 1 goto end

echo An error occurred during formatting

:end

echo Successfuly formatted the disk in drive A

<표 2-8> goto문을 이용한 배치 파일

2.1.6 CALL

배치 파일 내에서 명령의 중단이나 정지없이 또 다른 배치 파일을 불러

실행시키도록 하는 명령이다.

CALL [drive:][path] filename [batch-parameters]

 

문법 구조에서 알 수 있듯이 CALL 명령 다음에 현재 배치 파일 내에서

불러 실행할 다른 배치 파일의 실행 경로와 파일명을 적어 주면 된다. 또한

배치 파라메터에는 배치 파일과 함께 실행할 스위치나 파일명, %0∼%9까지

의 대체 변수, 환경 변수 등과 같은 것들이 올 수 있다. 그러나 다른 명령과

는 달리 파이프 기호나 리디렉션 기호를 CALL 명령과 함께 사용할 수 없다.

또한 배치 프로그램 안에서 반복해서 자신을 불러들일 수 있는 RECURSIVE

호출이 가능하지만 이 경우 탈출 명령을 만들어 두지 않으면 계속해서 반복

루프에 걸리게 된다. 이 때도 사용자가 강제로 배치 파일의 실행을 중지하기

위해서는 CTRL+C를 눌러 프로그램 실행을 그만두게 해야 한다.

CALL 명령은 배치 파일 중간에 사용되어 다른 배치 파일을 불러들여 실

행하고 다시 제어권을 CALL문이 사용된 배치 프로그램으로 넘기게 된다.

그러나 배치 파일의 마지막 줄에 다른 배치 파일을 실행하기 위해서는

CALL문을 사용하지 않아도 된다. 왜냐하면 제어권을 원래의 호출 프로그램

으로 되돌릴 필요가 없기 때문이다.

다음의 예를 비교해 보자. 외부에 CHECK.BAT이란 파일을 불러 실행하려

는 경우에 마지막 행에서 어떻게 차이가 나는지 알아볼 수 있는 예이다.

 

REM 이 파일은 마지막 행에 CALL을 사용한 예이다.

DIR *.* > PRN

CALL CHECK.BAT

<표 2-9> Call문을 이용한 배치 파일 호출 실행

 

REM 이 파일은 마지막 행에 직접 배치 파일을 적어 준 예

DIR *.* > PRN

CHECK.BAT

TIME

<표 2-9> Call문을 이용한 배치 파일 호출 실행

CALL문의 사용 없이 또다른 배치 파일을 불러서 처리하면 원래의 프로그

램으로 제어권이 되돌아오지 않기 때문에 원래 프로그램에 있는 호출된 배

치 파일명 뒤의 명령은 실행되지 않는다. 위의 예에서 직접 배치 파일명을

적어 준 경우는 다음에 따라오는 TIME이라는 명령을 실행하지 않고 프로그

램이 종료된다. 그 이유는 앞에서 설명했듯이 제어권이 되돌아오지 않고 종

료되기 때문이다.

CALL 명령과 비슷하게 작용하는 명령이 또 하나 있다. 바로 COMMAND

/C 명령인데, 이것은 DOS 3.3 이하 버전을 사용할 경우 또 다른 배치 파일

을 호출하기 위해 이용된다.

2.1.8 SHIFT

배치 파일의 변수들을 왼쪽으로 하나씩 이동시킨다. 다음과 같이

SHIFTIT.BAT란 파일을 만들자

 

ECHO OFF

REM 이 배치 파일은 SHIFT.BAT이며, SHIFT 명령의 이해를 돕기 위한 것이다

:REPEAT

ECHO %0

SHIFT

IF NOT "%0"=="" GOTO REPEAT

<표 2-11> Shift문을 이용한 배치 파일

SHIFT 명령이 어떻게 동작하는지 실험해 보기 위해 다음과 같이 입력해

보자

 

C:>SHIFT ONE TWO THREE

SHIFTIT

ONE

TWO

THREE

<표 2-11> 프롬프트에서 Shift문을 이용한 경우

결과는 위의 예에서와 같이 SHIFT, ONE, TWO, THREE가 순차적으로

한 줄씩 기록되는 결과가 나올 것이다. SHIFT 명령은 %0부터 %9까지 10개

의 변수에 대응되는 값들을 하나씩 왼쪽으로 이동시켜 대입시키게 된다. 하

지만 프로그래밍에서 사용되는 것처럼 오른쪽으로 이동되는 SHIFT 연산자

는 제공되지 않는다.

 

2.1.9 CHOICE

도스 6.0부터 포함된 명령으로 배치 파일을 사용자와 대화식으로 구성

하기 위한 명령이다. 다시 말해서 CHOICE는 지정된 키 중에서 사용자가 원

하는 키를 누를 때까지 정지 상태의 메시지 프롬프트를 제공한다. 사용 형

식은 다음과 같으며, 각 옵션과 스위치의 설명을 보도록 하자.

CHOICE [/C[:]keys] [/N] [/S] [/T[:]char, sec(nn)] [test]

 

♣ [파라메터와 스위치]

▶ text

사용자가 선택키를 고를 때까지 화면에 나타내고 싶은 메시지를 적어 줄

수 있다. 그러나 프롬프트 앞에 단지 문자열의 일부분으로써 스위치 구분자

(/)를 사용하려 한다면, 인용 부호(Quatation)를 이용해 표시해 줘야 한다.

▶ /C[:]keys

프롬프트에 할당된 키를 명시한다. 각 키의 정의는 대괄호([,]) 안에 정의

되며 콤마(,)에 의해 구분되고 물음표(?)가 뒤따라오게 된다. 그러나 만약 /c

스위치가 정의되지 않으면 디폴트 값인 YN(Yes, No)이 사용된다. 또한 구분

자인 콜론의 사용은 선택적이다.

▶ /N

CHOICE 명령에서 프롬프트를 표시하지 않는다. 그러나 프롬프트 앞에 나

타나는 text에서 지정한 메시지는 나타난다. 또 /N 스위치를 사용했다. 하더

라도 /C 스위치에 지정된 키의 사용은 유효하다. 다만 화면에 표시하지 않는

것뿐이므로 선택키가 안 보인다고 당황할 필요는 없다.

▶ /S

이 스위치는 선택키의 대문자와 소문자 입력을 구분하는 동작을 한다.

▶ /T[:]char,sec(nn)

이 스위치는 char에 지정된 디폴트 선택키를 sec(초단위)에 지정된 시간만

큼 지연시킨 후에 실팽되도록 한다. char에 사용되는 문자는 /C 스위치에서

지정한 선택문자들에 포함된 것이어야 하며, 지연 시간의 범위는 0부터 99초

까지의 초단위 시간을 사용할 수 있다.

CHOICE 명령이 ERRORLEVEL 변수는 /C 스위치에 처음 할당되는 키가

/T옵션에서 디폴트 키로 정해졌을 때, 이 키가 눌려지지 않고 시간이 지나

들어온 값이면 1, 두 번째 키는 2, 세 번째는 3과 같이 계속해서 주어지며 이
들 이외의 키가 눌려진 경우라면 경고음을 내보낸다. 그리고 각 스위치나

옵션에서 어떤 문제가 발생해서 에러가 발견되면 ERRORLEVEL값이 255에

설정되며, 사용자가 CTRL+BREAK나 CTRL+C를 눌러 중지한 경우라면

CHOICE 명령은 에러 레벨 값을 0에 설정하게 된다. 이러한 에러 레벨 변수

값을 배치 프로그램에서 사용할 경우에는 큰 값에서 작은 값으로 비교하는

내림차순으로 사용해야 한다. 예제를 한번 보도록 하자.

choice /c:ync YES, NO, or Continue

 

이 명령은 Y,N,C와 같은 세 가지 선택키를 보여주며 Yes, No, or Continue

와 같은 메시지를 앞에 보여주게 된다.

Yes, No, or Continue [Y,N,C]?

 

또 다른 예제인 /T 스위치를 사용한 예를 보도록 하자.

choice /c:ync /t:n,5

 

화면에 나타난 메시지 없이 다음의 [Y,N,C]? 라는 선택키만을 보이고 5초

동안 기다릴 것이다. 그러나 5초 후에 사용자가 누른 키가 없다면 CHOICE

는 디폴트로 설정된 N키를 선택하고 두 번째 키에 의한 에러 레벨 값 2를 내

보내게 되는 것이다.

이와 같은 에러 레벨을 이용한 배치 파일을 구성하기 위해서는 choice는

아주 다양한 배치의 실행을 돕는다. 만약 에러 레벨의 검사후 원치 않는 값

이면 프로그램을 빠져나오도록 구성할 수도 있다. 도스의 외부 명령어인

chkdsk를 실행하기 위해 다음과 같이 choice 명령을 구성할 수 있을 것이다.

 

choice /ty,5 chkdsk for your drive

if errorlevel 2 goto SkipCheck

CHKDSK c:

:SkipCheck

<예제 2-13> choice문을 이용한 배치 파일

디폴트 선택키로 y, n이 주어져 있다. /T스위치에서 5초 안에 키가 안 눌

려지면 Y키를 CHOICE에 전달하고 C 드라이브에 대한 CHKDSK를 실행하

게 된다. 그러나 5초 이내에 디폴트 키가 아닌 N키가 눌려지면 에러 레벨2

가 전달되어 SkipCheck라는 레이블로 이동하게 되어 CHKDSK C:의 실행이

건너띄게 된다.

실제로 배치 프로그래밍에서 CHOICE 명령과 같이 사용자의 키 입력이나

선택를 요구하는 부분을 필요로 하는 경우가 많이 있다. 이런 대화식 선택

화면을 구성하기 위해 CHOICE는 매우 유용한 명령으로 이용될 것이다.


posted by 초딩입맛제주아재
prev 1 next