Erlang (programmeertaal)
Van Wikipedia
Erlang is een concurrent declarative programmeertaal en runtime-systeem die geschikt is voor alle toepassingen. De sequentiële sub-set van Erlang is een functionele programmeertaal met strict evaluation, single assignment dynamic typing. Erlang is ontwikkeld door Ericsson voor gebruik in telecommunicatiehardware en is ontworpen om gedistribueerde, fout-tolerante, soft-real-time en non-stoptoepassingen te ondersteunen.
De naam is afkomstig van Agner Erlang die de eenheid Erlang heeft uitgevonden en is ook de afkorting van ERicsson LANGuage (Ericsson taal).
Inhoud |
[bewerk] Functionele taal
Code in Erlang ziet er zo uit:
-module(fact). -export([fac/1]). fac(0) -> 1; fac(N) where N > 0 -> N * fac(N-1).
Hieronder een voorbeeld van Quicksort:
%% 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]).
Het bovenstaande voorbeeld roept de functie qsort
recursief aan tot er niets meer is om te sorteren. De uitdrukking [ X || X <- Rest, X < Pivot]
kan gelezen worden als "Kies alle X
waar X
een element is van Rest
en X
kleiner is dan Pivot
". Dit heeft een erg makkelijke manier om lijsten af te handelen tot gevolg. Aangezien elke booleaanse uitdrukking tussen twee verschillende types van gegevens kan geevalueerd worden, is de evaluatie duidelijk - 1 < a
zal bijvoorbeeld true
opleveren.
Desondanks kan een vergelijkende functie gebruikt worden als de volgorde waarop Erlang haar antwoordwaarde baseert (true
of false
), gewijzigd moet worden. Als we bijvoorbeeld een geordende lijst willen waar a > 1
als waarde true
opleverd.
[bewerk] Concurrency georiënteerde taal
De belangrijkste sterkte van Erlang is ondersteuning voor concurrency. De taal heeft een kleine maar krachtige set van primitieven voor de aanmaak van threads en om de communicatie tussen deze threads te verzorgen. De positie van thread is transparant (dit kan in hetzelfde lopende systeemproces zijn of op een andere computer).
Voorbeeldcode:
Pid = spawn(Mod, Func, Args) % voer functie Func uit als een nieuwe thread
Pid ! een_bericht % verzend bericht naar de thread (asynchroon)
receive % ontvang bericht verzonden naar deze thread een_bericht -> doe_iets end.
Erlang bevat mechanismes om foutmeldingen af te handelen en om een hoge beschikbaarheid van het hele systeem te verzekeren. Dynamische vervanging van code (hot swapping) wordt ook ondersteund.
[bewerk] Distributie
Erlang werd vrijgegeven als open-source om niet meer afhankelijk te zijn van één bron en om de taal bekender te maken. Het pakket dat de taal samen met bibliotheken en een real-time gedistribueerde database bevat is gekend onder de naam Open Telecom Platform, OTP. Ericsson biedt commerciële ondersteuning aan voor Erlang.
Sinds de uitgave van de open-sourceversie in 1998 zijn bedrijven uit de hele wereld Erlang gaan gebruiken zoals Nortel en T-Mobile. Desondanks is de taal nog niet uitgegroeid tot een wijdverspreide en belangrijke programmeertaal.
Vanaf 2005 is Erlang in actieve ontwikkeling en worden er vaak nieuwe versies vrijgegeven. De taal is beschikbaar voor verscheidene Unix varianten en Windows.
[bewerk] Voordelen
- Ondersteuning voor superb voor concurrency is aanwezig (het is geen probleem om honderden of zelfs duizenden threads te creëren).
- Hoge productiviteit van de programmeur (een onderzoek door Ericsson beweert dat de productiviteit 4 keer hoger is dan bij C).
- Eenvoudig om aan te leren: Erlang is geen academische programmeertaal maar een praktische taal ontworpen voor gebruik door programmeurs bij Ericsson.
- Schaalbaarheid: grote systemen met miljoenen regels code werden al geschreven in Erlang.
[bewerk] Nadelen
- Niet bedoeld voor toepassingen die een hoge performantie vragen (het is een geïnterpreteerde taal die garbage collection gebruikt).
- Gebrek aan static typing: vele fouten worden vaak pas opgemerkt tijdens het draaien van de toepassing.
- Omdat het geen overheersende programmeertaal is, zijn er niet veel hulpmiddelen, boeken, bibliotheken en bekwame ontwikkelaars. Zo is ondersteuning voor grafische gebruikersinterfaces nog steeds in de beginfase.
[bewerk] Zie ook
- ejabberd is een Jabber/XMPP-server geschreven in Erlang.
- Wings 3D is een 3D modelleerder geschreven in Erlang.
- Yaws is een webserver geschreven in Erlang.
- Tsung is een benchmarkprogramma geschreven in Erlang.