얼랭 (프로그래밍 언어)

위키백과, 우리 모두의 백과사전.
이동: 둘러보기, 검색
얼랑 로고
LYME is Erlang-based and competing with LAMP

얼랭(Erlang, 영어: IPA[ˈɜrlæŋ])은 범용 병렬 프로그래밍 언어이다. 함수형 언어가 효율적으로 산업 현장등에서 사용되는 유명한 사례이다.

원래는 에릭슨(Ericsson)사에서 스위칭 소프트웨어에서 사용하기 위해 개발했지만, 1998년오픈 소스로 공개되었다.

흔히 Erlang이라는 이름이 Ericsson Language에서 따온 것이라고 생각하지만, 실제로는 통신이론을 연구한 덴마크수학자 Agner Krarup Erlang의 이름에서 따온 것이다.

함수형 언어[편집]

다음은 계승을 구하는 코드이다.

 -module(fact).
 -export([fac/1]).
 
 fac(0) -> 1;
 fac(N) where N > 0 -> N * fac(N-1).

다음은 퀵소트 알고리즘을 구현한 것이다.

 %% quicksort(List)
 %% Sort a list of items
 -module(quicksort).
 -export([qsort/1]).
 
 qsort([]) -> [];
 qsort([Pivot|Rest]) ->
     qsort([ X || X <- Rest, X < Pivot]) ++ [Pivot] ++ qsort([ Y || Y <- Rest, Y >= Pivot]).


qsort 함수는 더이상 정렬할 필요가 없을 때까지 자신을 재귀적으로 호출한다.

 [ X || X <- Rest, X < Pivot]

이 부분은 "Rest원소이고, Pivot보다 작은 모든 X를 선택하라"는 의미이다.

바깥고리[편집]