goto 문
goto 문은 여러 프로그래밍 언어에 등장하는 프로그램의 어느 부분에서 행번호나 레이블이 있는 다른 부분으로 건너뛸 때(one-way transfer) 사용하는 명령이다. 프로그램의 흐름을 바꾸는 기본적인 명령이며, 다른 흐름 제어문도 컴파일러가 goto 문과 비슷하게 바꾼다.
goto 문은 포트란, 알골, 코볼, 스노볼, 베이직, 커먼 리스프, C, C++, D, 파스칼, 펄, PHP7 등지에서 사용되며, 특히 어셈블리에서 많이 발견된다. 어셈블리어에서는 goto 대신에 BRA(branch에서 유래), JMP, JUMP 등으로 쓰이기도 한다.
그러나 goto 문이 모든 고급언어에서 사용 가능한 것은 아니다. 예를 들어, 자바와 같은 언어에서 goto는 예약어이긴 하지만 아무 기능을 하지 않는다.
비판
편집고급 언어에서 goto 문은 비판의 대상이 되어 왔는데, goto 문이 과도하게 사용되면 읽고 유지하기 힘든 스파게티 코드가 나오기 쉽기 때문이다. 구조적 프로그래밍은 1960년대와 1970년대에 더 두드러졌는데, 많은 컴퓨터 과학자들의 결론은 프로그램이 항상 goto 문 대신 일명 ‘구조적’인 흐름 제어문(순환문, if-then-else문)을 사용해야 한다는 것이다.[1] 그러나 goto 문의 사용이 종종 나쁜 습관이긴 하지만, 많은 프로그래밍 언어에서 goto 문을 사용하지 않고는 간단히 되지 않는 경우(중첩 순환문을 빠져나갈 때나 예외 처리할 때)가 있다고 주장하는 사람들이 있다.
goto 문에 대한 한 가지 유명한 비판은 1968년에 쓰여진 에츠허르 데이크스트라의 'goto 문의 해로움'[2]이라는 서신에 쓰여있다. 이 서신에서 데이크스트라는 더 높은 수준의 언어에서 goto 문을 제한할 것을 주장했다. 이는 프로그램의 정확성을 분석하고 증명하는 것을(특히 순환문을 포함해서) 어렵게 하기 때문이라고 설명하였다.
도널드 커누스의 'goto 문을 사용한 구조적 프로그래밍'[3]에서는 goto의 적절한 위치를 고찰한다. 일반적으로 이것들은 특정 프로그래밍 구조가 없기 때문이다. 이런 경우들에서 goto 문은 항상 원하는 구조를 에뮬레이트 할 수 있고, 따라서 이것이 프로그래밍의 기본적인 요소의 하나라는 것이다. 다른 해법은 매크로를 이용하여 원하는 제어 구조를 만드는 것이다.(리스프와 그 변종이나 포스에서는 이렇게 해서 대부분의 일을 할 수 있다.)
변형
편집- 계산된 goto 문(Computed GOTO): 수식의 값에 따라 몇 군데의 레이블로 분기하거나, 변수에 저장되어 있는 레이블로 분기한다. 계산된 goto 문은 보통 goto 문보다 문제가 더 심각한데, 프로그래머가 어떤 구문을 본다고 해도 다음에 무엇이 수행될지 알 수 없기 때문이다.
- 컨티뉴에이션(continuation): 프로그램의 임의의 위치에서 기억했던 위치로 분기하는 점에서 계산된 goto 문과 비슷하다. 그러나 이어하기는 현재 함수를 벗어날 수 있지만 goto 문은 그렇지 않기 때문에 이어하기가 더 유연하다. 이어하기를 실행하면 보통 분기하는 것뿐만 아니라 보통 프로그램의 호출 스택을 조절하는 것까지 한다.
- 베이직 언어를 패러디한 인터칼과 같은 언어에서는 COME FROM 문을 goto 문 대신에 쓰기도 한다.
- 펄과 같은 언어에서는 @_variable에 있는 현재 인자를 사용하여 서브루틴을 호출하는 방법으로 goto 문을 사용한다.
읽을거리
편집같이 보기
편집각주
편집- ↑ 데니스 리치; 브라이언 커니핸 (1998). 《C 언어 프로그래밍》 2판. 대영사. 91쪽. ISBN 89-7163-026-4.
- ↑ (영어) 에츠허르 데이크스트라: Go To Statement Considered Harmful Archived 2007년 7월 3일 - 웨이백 머신. Communications of the ACM 11:3 (1968), 147–148.
- ↑ (영어) 도널드 커누스: Structured Programming with Goto Statements. Computing Surveys 6:4 (1974), 261–301.