(アーラン)は、コンピュータにおいて汎用的な用途に使うことができる並行処理指向のプログラミング言語および実行環境。の直列処理のサブセットの言語は、関数型言語であり、先行評価を行い、変数への代入は1回限りであり、動的型付けである。はエリクソンにより次の条件のシステムを構築できるよう設計された。ホットスワップが可能であり、稼働中のシステムを停止すること無くのプログラムを変更することができる。は、当初はエリクソン社内部だけで使われる非公開の技術であったが、1998年にオープンソースとして公開された。エリクソンによるの実装は基本的にはインタプリタであるが、というコンパイラも同社の実装に含まれている。ただしはが動作する全てのプラットフォームで使えるわけではない。においては、マルチスレッドの処理の並行性はプログラム開発者(プログラマ)にとって明瞭である。これに対し、ほとんどのプログラミング言語においては、マルチスレッドは複雑で誤りを犯しがちな分野である。で「プロセス」(スレッド) を生成し管理する手法はごく平凡な方法である。は数学者のアグナー・アーランから名前をとって命名された。一方で、エリクソン社内で非常によく使われたため「」にちなんで命名されたと一部の人々は思っている。当時エリクソンのコンピュータ科学研究所の所長であったビャーネ・デッカーによれば、この名前に関する2重性については意図的なものだとのことである。のソースコードの例を示す。次のソースコードはによるクイックソートのアルゴリズムの実装である。この例では関数codice_1の再帰呼び出しを行っている。再帰呼び出しはソート処理の対象が無くなった時点で終了する。式codice_2は「 codice_3をcodice_4の要素として、codice_3がcodice_6より小さい全てのcodice_3を選択する。」と読むことができる。このようにではリストを非常に簡単に扱うことができる。では異なる2つのデータ型の値の間であらゆる論理式を評価できるため、式の評価は単純である。例えば、codice_8はcodice_9を返す。ただしにおける戻り値(codice_9あるいはcodice_11)を返す基礎的なしくみを変更する必要がある場合には、比較関数を使うことができる。例えば、codice_12がcodice_9と評価される比較順序により順序付けられたリストが必要な場合などである。次のソースコードではリストをリスト要素の長さを基準にしてソートする。の主な特長は、並行処理のサポートである。における並行処理は、複数の「プロセス」を生成し、それらの間で通信を行うための、簡潔で強力な機能群によって支えられている。なお、が提供する「プロセス」は、オペレーティングシステムが提供するプロセスやスレッドとは異なり、の仮想機械(VM)によって管理される。「プロセス」の生成オーバーヘッドは約300ワード程度に抑えられており、大量の「プロセス」を、性能を低下させずに生成できる。あるベンチマークでは2000万個の「プロセス」を並行実行できることが示された。これ以降の記述ではにおける「プロセス」を括弧無しで言及する。におけるプロセス間の通信は、非共有かつ非同期のメッセージ転送システムによって行われる。のプロセスは全てそれぞれの「メールボックス」をもつ。メールボックスには他のプロセスから受信したメッセージが格納される。その後、メールボックスに格納されたメッセージがメールボックスを所有するプロセスによって処理される。そのときのプロセスはメッセージを得るためにcodice_14という基本操作を行う。メッセージを得る過程ではパターンマッチングが行われる。まずメッセージ制御ルーティンが1番目のメッセージに対して各パターンがマッチするかどうか調べる。2番目以降のメッセージに対しても同様のことを行う。マッチングは、マッチするメッセージに出会うまで行われる。メッセージが処理されると、メッセージはメールボックスキューから除去され、プロセスは復帰して続きの処理を行う。の構成要素は何であれメッセージとして使うことができる。の基本要素である整数、浮動小数点数、文字、アトムも、またタプル、リスト、さらには関数さえも、メッセージとして扱うことができる。ソースコードの例を示す。では異なるノード (コンピュータ) に分散した複数のプロセスを互いに連携させて動作させるためのサポートも組み込みで備えている (分散処理) 。プロセスは遠隔のノードに生成することができ、遠隔ノード上のプロセスとのプロセス間通信は透過的である。すなわち、遠隔ノード上のプロセスとのプロセス間通信は、同じノード上のプロセスとのプロセス間通信と全く同じように行われる。での並行処理では、エラー処理の基本的な方法をサポートしている。あるプロセスが異常をきたすと、プロセスは手際良く終了し、そのプロセスを制御しているプロセス (何らかのアクションをとることができるプロセス) にメッセージを送信する。このエラー処理の方法により、ソースコードの保守性を高め複雑性を低減することができる。エリクソンはをオープンソースとして、1998年に公開した。その意図は、特定企業からの独立性を確保することと、に対する人々の認知を高めることであった。ライブラリとリアルタイムデータベース「」と共に配布される プログラミング言語の配布形式は、 (OTP) と呼ばれている。エリクソンおよび数社の企業は、技術に対する商用サポートを提供している。をオープンソースとして公開する方針を採ってからは、世界中のいくつもの企業によって採用されている。ノベル・ネットワークス、ティー・モバイルなどの企業がを採用している。同社ではこれまで何十ものプロジェクトでを採用してきた。とりわけ大規模なものは非常にスケーラブルな AXD301 ATM スイッチのプロジェクトである。を採用しているエリクソン以外の組織としては、ノルテル、ドイチェ・フルークズィヒャルング(航空管制を担うドイツの政府組織)、ティー・モバイルなどが挙げられている。2014年にはWhatsApp、ドワンゴ、LINEなどがErlangを採用していることを表明した。2015年現在、は活発に開発が続けられており、定期的に新リリースを公開している。は、いくつかのUNIXに似たオペレーティングシステムおよび上で使うことができる。ウェブサーバ
出典:wikipedia
LINEスタンプ制作に興味がある場合は、
下記よりスタンプファクトリーのホームページをご覧ください。