Delphi [델파이 문법] 프로시저와 함수 #7
2012.08.13 23:23
■ 값 및 변수 파라미터
대부분의 파라미터는 값 파라미터(기본) 또는 변수(var) 파라미터입니다. 값파라미터는 값
에 의해 전달되는 반면, 변수 파라미터는 참조에 의해 전달됩니다. 이것이 의미하는 것을 알
아보기 위해 다음의 예제를 살펴봅시다.
루틴 선언에서 var 파라미터를 지정하면 루틴을 호출할 때 대입 가능한 표현식을 전달해야
이 함수들은 같은 결과를 리턴하지만, 두 번째 함수인 DoubleByRef만 파라미터로 전달된
변수의 값을 변경할 수 있습니다. 다음과 같이 이 함수들을 호출한다고 생각해봅시다.
값 파라미터는 프로시저나 함수 호출에 의해 전달된 값으로 초기화된 지역 변수처럼 동작합
반면, 변수 파라미터는 복사본이 아니라 포인터처럼 동작합니다. 함수나 프로시저의 바디에
코드 실행이 끝난 다음, DoubleByValue로 전달된 변수 I는 처음에 대입한 값과 같은 값을
가집니다. 그러나 DoubleByRef로 전달된 변수 V는 다른 값을 가지게 됩니다.
값 파라미터는 프로시저나 함수 호출에 의해 전달된 값으로 초기화된 지역 변수처럼 동작합
니다. 변수를 값 파라미터로 전달하면 프로시저나 함수는 그 변수의 값을 복사합니다. 이 복
사본을 변경하더라도 원래의 변수에는 아무런 영향을 주지 않으며, 프로그램 실행이 호출했
던 부분으로 리턴된 후에는 변경되었던 내용을 잃어버립니다.
반면, 변수 파라미터는 복사본이 아니라 포인터처럼 동작합니다. 함수나 프로시저의 바디에
서 파라미터를 변경하면, 프로그램 실행이 호출했던 부분으로 리턴되어 파라미터 이름 자체
는 유효 범위를 벗어난 후에도 그 변경 내용은 계속 유지됩니다.
같은 변수를 둘 이상의 var 파라미터로 전달하더라도 복사본은 만들어지지 않습니다. 이는
아래의 예제에서 설명합니다.
이 코드가 실행된 후에 I의 값은 3이 됩니다.
루틴 선언에서 var 파라미터를 지정하면 루틴을 호출할 때 대입 가능한 표현식을 전달해야
합니다. 여기서 대입 가능한 표현식에는 변수, 타입 지정 상수({$J+} 상태), 역참조
(dereference) 포인터, 인덱스된 변수가 해당됩니다. 이전 예제의 경우를 다시 예로 들면,
DoubleByValue(7)는 적합하지만, DoubleByRef(7)는 에러를 일으킵니다.
DoubleByRef(MyArray[I])처럼 var 파라미터로 전달되는 인덱스 혹은 포인터 역참조는
루틴이 실행되기 전에 한번 계산됩니다.
■ 상수 파라미터
상수(const) 파라미터는 지역 상수 또는 읽기 전용 변수와 비슷합니다. 상수 파라미터는 프
로시저나 함수의 바디에서 값을 대입할 수 없다는 것과 또다른 루틴에 값을 var 파라미터로
전달할 수 없다는 것만 제외하면, 상수 파라미터는 값 파라미터와 유사합니다. (그러나 객체
다음은 SysUtils 유닛에 있는 CompareStr 함수의 헤더입니다.
참조를 상수 파라미터로 전달하는 경우, 객체의 속성을 수정할 수는 있습니다.)
const를 사용하면 컴파일러는 구조 타입 파라미터와 문자열 타입 파라미터에 대해 코드를
최적화할 수 있습니다. 또한 의도하지 않게 파라미터를 참조로(var) 다른 루틴으로 전달하
는 것도 막을 수 있습니다.
다음은 SysUtils 유닛에 있는 CompareStr 함수의 헤더입니다.
S1 및 S2는 CompareStr의 바디에서 수정되지 않기 때문에 상수 파라미터로 선언될 수 있
습니다.