하스켈
하스켈 또는 해스켈(영어: Haskell IPA: [ˈhæskəl])은 순수 함수형 프로그래밍 언어이다. 교육계와 산업계 모두를 위해 설계된 하스켈은 타입클래스, 모나딕 IO와 같은 여러 프로그래밍 언어의 기능을 개척하였다. 하스켈의 주된 구현체는 GHC(Glasgow Haskell Compiler)이다.
패러다임 | 함수형 |
---|---|
설계자 | Simon Peyton Jones, Paul Hudak, Philip Wadler, .. |
발표일 | 1990년[1] |
최근 버전 | Haskell 2010[2] |
최근 버전 출시일 | 2010년 7월 |
자료형 체계 | 강적, 정적, 추론 |
운영 체제 | 크로스 플랫폼 |
웹사이트 | www |
주요 구현체 | |
GHC, Hugs, NHC, JHC, Yhc | |
Helium, Gofer | |
영향을 받은 언어 | |
리스프, 미란다, 스킴, APL, ML, .. | |
영향을 준 언어 | |
머큐리, 비주얼 베이직 닷넷, 파이썬, F 샤프, 스칼라 .. |
명칭
편집논리학자 해스켈 커리에서 이름을 따왔다. 그러므로 본디 ‘해스켈’로 불러야 하지만[3], 대한민국에서는 ‘하스켈’이 프로그래밍 언어를 가리키는 말로 널리 쓰여 굳어졌다.
역사
편집1985년에 개발된 미란다가 하스켈의 전신이라고 할 수 있다.
1987년 오리건주 포틀랜드에서 열린 ‘함수형 프로그래밍 언어와 컴퓨터 구조에 관한 총회’(Functional Programming Languages and Computer Architecture, FPCA '87)에서 있었던 회의에서, 난립하고 있는 함수형 언어들을 통합 정리해서 훗날 언어 설계의 기반이 될 수 있는 일반적인 순수 함수형 프로그래밍 언어를 만들자는 데에 참가자들의 뜻이 모였고 위원회가 발족되었다[4]. 하스켈의 첫 버전(‘하스켈 1.0’)은 1990년에 완성되었다[5]. 위원회의 노력은 1997년 말까지 다양한 설계안으로 이어져 마침내 ‘하스켈 98’이라는 성과가 나왔다. 하스켈 98은 교육용이나 확장을 덧붙이는 토대로 쓸 수 있는 안정적이고, 작고, 이식성 좋은 언어 표준을 의도한 결과물로서 표준 라이브러리가 포함되어 있었다. 또한 위원회는 하스켈 98의 확장 기능과 더불어 하스켈 98에 실험적인 기능을 덧붙이거나 합친 변형이 만들어지는 것을 열렬히 환영했다.
하스켈 98 언어 표준은 1999년 1월 〈하스켈 98 보고서〉(The Haskell 98 Report)라는 이름으로 정식 공개되었다. 그리고 2003년 1월에는 〈하스켈 98 언어와 라이브러리: 개정 보고서〉(Haskell 98 Language and Libraries: The Revised Report)라는 이름으로 개정판이 나왔다[6]. 하스켈을 실제 컴퓨터로 쓸 수 있게 구현한 ‘글래스고 하스켈 컴파일러’와 ‘허그스’가 사실상의 표준 역할을 하면서 하스켈은 지금도 끊임없이 발전하고 있다.
2006년초에 하스켈 98 표준의 뒤를 이을 표준에 관한 논의가 시작되었다. 새로운 표준은 비공식적으로 ‘하스켈 프라임’(Haskell′)이라는 이름으로 불렸으며, 2009년 11월 새로운 표준의 첫 번째 판인 하스켈 2010이 발표되었다. 하스켈 2010은 다른 프로그래밍 언어와 호환할 수 있는 인터페이스인 외부 함수 인터페이스를 지원하고, 일부 문법이 변경되었으며, n+k 패턴이라 불리는 문법 형식이 금지되었다.
특징
편집하스켈의 특징으로는 패턴 매칭, 커링, 조건제시법, 가드, 연산자 정의 등을 들 수 있다. 재귀 함수나 대수적 자료형도 지원되고, 느긋한 계산법 또한 하스켈의 특징으로 유명하다. 모나드, 타입 클래스 등은 하스켈만의 독창적인 개념이며 이러한 특징들은 절차적인 프로그래밍 언어에서 매우 힘들었던 순수 함수 정의를 손쉽게 만든다.
수학의 한 특이 분야인 범주론의 개념들, 특히 함수의 개념의 추상화된 형태인 사상과 모나드(영어: monad)를 차용하여 가져온 언어인데, 이를 통해 함수를 대상으로써 다룸에 있어서 명확성을 가질 수 있다.
2002년을 기준으로 하스켈은 느긋한 계산법을 쓰는 함수형 언어 가운데 가장 활발한 연구가 이루어지는 언어로 볼 수 있다. 언어의 변형도 몇 가지 개발되었다. 매사추세츠 공과대학교와 글래스고 대학교가 개발한 버전은 병렬화가 가능하기 때문에 ‘병렬 하스켈’이라고 불린다. 이후 병렬화와 분산 처리를 더욱 강화한 ‘분산 하스켈’과 에덴 프로그래밍 언어가 나왔고, 느긋한 계산법 대신 적극적인 계산법을 쓰는 ‘적극적 하스켈’이 있으며 하스켈에 객체 지향 개념을 도입한 버전으로 ‘하스켈++’, ‘오하스켈’, 몬드리안 프로그래밍 언어 등등이 있다.
하스켈과 비슷한 언어로 그래픽 사용자 인터페이스 개발에 새로운 방법을 도입한 클린이 있다. 이 언어와 하스켈의 가장 큰 차이점은 입출력을 위해 모나드 대신에 유일형을 사용한다는 것이다.
적용
편집하스켈 사용자의 수는 상대적으로 적은 편이지만, 그 강력함 때문에 몇몇 프로젝트를 쉽게 해주었다. 퍼그스(Pugs)는 펄 6의 컴파일러와 인터프리터를 구현한 것인데, 개발 기간은 지극히 짧았지만 만들어진 지 몇 달도 채 되지 않아 꽤 쓸 만하다는 평을 받았다. 서브버전과 비슷한 버전 관리 체계인 다크스(Darcs)가 하스켈로 만들어지기도 했고, 린스파이어는 시스템 도구 개발을 위한 언어로 하스켈을 선택했다[7].
구현
편집- 글래스고 하스켈 컴파일러 는 하스켈 컴파일러(ghc)와 대화식 환경(ghci)로 되어 있다.
- Hugs는 하스켈 인터프리터이다.
예제
편집다음은 계승을 하스켈로 구현하는 몇 가지 방법이다.
패턴 매칭과 꼬리 재귀(영어: tail recursion)을 이용한 방법:
fac 0 = 1
fac n = n * fac (n-1)
if-then-else와 꼬리 순환을 이용한 방법:
fac n = if n > 1 then n * fac (n-1) else 1
고차 함수(high-order function)을 이용한 방법:
fac n = foldl1 (*) [n..1]
product 함수를 이용한 방법(product 함수는 위의 foldl1 (*)과 같다.):
fac n = product [n..1]
각주
편집- ↑ Hudak 등. 2007.
- ↑ Marlow, Simon (2009년 11월 24일). “Announcing Haskell 2010”. 《Haskell》 (메일링 리스트). 2011년 3월 12일에 확인함.
- ↑ Chevalier, Tim (2008년 1월 28일). “anybody can tell me the pronuncation of "haskell"?”. Haskell-cafe. 2011년 3월 12일에 확인함.
- ↑ Preface
- ↑ “The History of Haskell”. 2009년 4월 29일에 원본 문서에서 보존된 문서. 2006년 9월 27일에 확인함.
- ↑ The Haskell 98 Language Report
- ↑ [1]Archived 2017년 12월 27일 - 웨이백 머신 [Debian-haskell] Linspire/Freespire Core OS Team and Haskell
외부 링크
편집- (영어) 하스켈 - 공식 웹사이트
- (영어) Programming in Haskell
- (한국어) 하스켈로 배우는 프로그래밍(번역)