Erlang - Guide rapide

Erlang est un langage de programmation fonctionnel qui dispose également d'un environnement d'exécution. Il a été construit de manière à intégrer la prise en charge de la concurrence, de la distribution et de la tolérance aux pannes. Erlang a été développé à l'origine pour être utilisé dans plusieurs grands systèmes de télécommunication d'Ericsson.

La première version d'Erlang a été développée par Joe Armstrong, Robert Virding et Mike Williams en 1986. C'était à l'origine un langage propriétaire au sein d'Ericsson. Il a ensuite été publié en tant que langage open source en 1998. Erlang, avec OTP, une collection d'intergiciels et de bibliothèques à Erlang, sont maintenant pris en charge et maintenus par l'unité de produit OTP d'Ericsson et largement appelésErlang/OTP.

Pourquoi Erlang?

Erlang doit être utilisé pour développer votre application, si vous avez les exigences suivantes -

  • L'application doit gérer un grand nombre d'activités simultanées.

  • Il doit être facilement distribuable sur un réseau d'ordinateurs.

  • Il devrait y avoir une possibilité de rendre l'application tolérante aux pannes aux erreurs logicielles et matérielles.

  • L'application doit être évolutive. Cela signifie qu'il devrait avoir la capacité de s'étendre sur plusieurs serveurs avec peu ou pas de changement.

  • Il doit être facilement évolutif et reconfigurable sans avoir à arrêter et redémarrer l'application elle-même.

  • L'application doit être sensible aux utilisateurs dans certains délais stricts.

Le site officiel d'Erlang est https://www.erlang.org/.

Maintenant, avant de pouvoir commencer à travailler sur Erlang, vous devez vous assurer que vous disposez d'une version entièrement fonctionnelle d'Erlang en cours d'exécution sur votre système. Cette section examinera l'installation d'Erlang et sa configuration ultérieure sur une machine Windows pour démarrer avec Erlang.

Assurez-vous que la configuration système requise suivante est remplie avant de procéder à l'installation.

System Requirements

Mémoire 2 Go de RAM (recommandé)
Espace disque Aucune exigence minimale. De préférence d'avoir suffisamment de stockage pour stocker les applications qui seront créées avec Erlang.
Version du système d'exploitation Erlang peut être installé sur Windows, Ubuntu / Debian, Mac OS X.

Téléchargement d'Erlang

Pour télécharger Erlang, il faut aller à l'url suivante - www.erlang.org/downloads .

Cette page propose une variété de téléchargements ainsi que les étapes nécessaires pour télécharger et installer la langue sur les plates-formes Linux et Mac.

Cliquez sur 'OTP 18.3 Windows 32-bit Binary File' pour commencer le téléchargement du fichier d'installation Erlang Windows.

Installation d'Erlang

Les étapes suivantes détaillent comment Erlang peut être installé sur Windows -

Step 1- Lancez le programme d'installation téléchargé dans la section précédente. Une fois le programme d'installation lancé, cliquez sur Exécuter.

Step 2 - Cliquez sur Suivant sur l'écran suivant pour accepter les composants par défaut, qui seront installés.

Step 3 - Acceptez le chemin d'installation par défaut et cliquez sur Suivant.

Step 4 - Acceptez l'élément par défaut du menu Démarrer, qui sera créé et cliquez sur Suivant.

Step 5 - Une fois l'installation terminée, cliquez sur Fermer pour terminer l'installation.

Configuration Erlang

Une fois l'installation terminée, la configuration suivante doit être effectuée pour s'assurer qu'Erlang commence à fonctionner sur le système.

OS Production
les fenêtres Ajoutez la chaîne; C: \ Program Files (x86) \ erl7.2.1 \ bin OU C: \ Program Files \ erl7.2.1 \ bin à la fin de la variable système PATH.

Si vous ouvrez maintenant l'invite de commande et tapez erl, vous devriez pouvoir obtenir l'invite de commande erl.

Félicitations, vous avez maintenant configuré avec succès erl sur votre ordinateur portable.

Installation de plug-ins sur les IDE populaires

Erlang en tant que langage de programmation est également disponible dans les IDE populaires tels que Eclipse and IntelliJ. Voyons comment nous pouvons obtenir les plugins requis dans ces IDE afin que vous ayez plus de choix pour travailler avec Erlang.

Installation dans Eclipse

Step 1 - Ouvrez Eclipse et cliquez sur l'élément Menu, Help → Install New Software.

Step 2 - Entrez le lien Travailler avec comme https://download.erlide.org/update

Cliquez ensuite sur Ajouter.

Step 3 - Vous serez alors invité à entrer un nom pour le plugin, entrez le nom comme Erlide. Cliquez sur OK.

Step 4- Eclipse analysera ensuite le lien fourni et obtiendra les plugins requis. Vérifiez les plugins et cliquez sur Suivant.

Step 5- Dans la boîte de dialogue suivante, Eclipse affichera tous les composants qui seront installés. Cliquez sur Suivant.

Step 6- Dans la boîte de dialogue suivante, Eclipse demandera simplement de revoir les composants en cours d'installation. Cliquez sur Suivant.

Step 7- Dans la boîte de dialogue suivante, il vous suffit d'accepter le contrat de licence. Enfin, cliquez sur le bouton Terminer.

L'installation commencera alors, et une fois terminée, il vous demandera de redémarrer Eclipse.

Une fois Eclipse redémarré, lorsque vous créez un projet, vous pourrez également voir Erlang en option.

Installation dans IntelliJ

Veuillez suivre les étapes suivantes pour installer IntelliJ sur votre ordinateur.

Step 1 - Ouvrez IntelliJ et cliquez sur Configurer → Plugins.

Step 2- Tapez Erlang dans la zone de recherche. Vous obtiendrez le plugin Erlang sur le côté droit de l'écran. Cliquez sur le bouton Installer.

Step 3 - Une fois le plugin Erlang installé, vous serez invité à redémarrer l'EDI.

Lorsque vous redémarrez l'EDI et essayez de créer un nouveau projet, vous verrez l'option pour créer un projet Erlang.

Afin de comprendre la syntaxe de base d'Erlang, examinons d'abord un simple Hello World programme.

Exemple

% hello world program
-module(helloworld). 
-export([start/0]). 

start() -> 
   io:fwrite("Hello, world!\n").

Les choses suivantes doivent être notées à propos du programme ci-dessus -

  • Le signe% est utilisé pour ajouter des commentaires au programme.

  • L'instruction module est comme l'ajout d'un espace de noms comme dans n'importe quel langage de programmation. Donc ici, nous mentionnons que ce code fera partie d'un module appeléhelloworld.

  • La fonction d'exportation est utilisée pour que toute fonction définie dans le programme puisse être utilisée. Nous définissons une fonction appelée start et pour utiliser la fonction start, nous devons utiliser l'instruction d'exportation. le/0 signifie que notre fonction 'start' accepte 0 paramètre.

  • Nous définissons enfin notre fonction de démarrage. Ici, nous utilisons un autre module appeléioqui a toutes les fonctions d'entrée-sortie requises dans Erlang. Nous avons utilisé lefwrite pour afficher «Hello World» sur la console.

La sortie du programme ci-dessus sera -

Production

Hello, world!

Forme générale d'une déclaration

En Erlang, vous avez vu qu'il existe différents symboles utilisés en langue Erlang. Passons en revue ce que nous avons vu d'un simple programme Hello World -

  • Le symbole du trait d'union (–)est généralement utilisé avec le module, la déclaration d'importation et d'exportation. Le symbole du trait d'union est utilisé pour donner un sens à chaque instruction en conséquence. Ainsi, des exemples du programme Hello world sont présentés dans le programme suivant -

-module(helloworld).
-export([start/0]).

Chaque instruction est délimitée par le point (.)symbole. Chaque instruction dans Erlang doit se terminer par ce délimiteur. Un exemple du programme Hello world est illustré dans le programme suivant -

io:fwrite("Hello, world!\n").
  • Le slash (/) Le symbole est utilisé avec la fonction pour définir le nombre de paramètres acceptés par la fonction.

-export([start/0]).

Modules

Dans Erlang, tout le code est divisé en modules. Un module se compose d'une séquence d'attributs et de déclarations de fonctions. C'est comme un concept d'espace de noms dans d'autres langages de programmation qui est utilisé pour séparer logiquement différentes unités de code.

Définition d'un module

Un module est défini avec l'identifiant du module. La syntaxe générale et l'exemple sont les suivants.

Syntaxe

-module(ModuleName)

le ModuleName doit être le même que le nom du fichier moins l'extension .erl. Sinon, le chargement de code ne fonctionnera pas comme prévu.

Exemple

-module(helloworld)

Ces modules seront traités en détail dans les chapitres suivants, c'était juste pour vous aider à comprendre comment un module devrait être défini.

Déclaration d'importation dans Erlang

Dans Erlang, si l'on veut utiliser la fonctionnalité d'un module Erlang existant, on peut utiliser l'instruction import. La forme générale de la déclaration d'importation est décrite dans le programme suivant -

Exemple

-import (modulename, [functionname/parameter]).

Où,

  • Modulename - C'est le nom du module qui doit être importé.

  • functionname/parameter - La fonction dans le module qui doit être importée.

Changeons la façon dont nous écrivons notre programme hello world pour utiliser une instruction d'importation. L'exemple serait comme indiqué dans le programme suivant.

Exemple

% hello world program
-module(helloworld).
-import(io,[fwrite/1]).
-export([start/0]).

start() ->
   fwrite("Hello, world!\n").

Dans le code ci-dessus, nous utilisons le mot-clé import pour importer la bibliothèque 'io' et plus précisément le fwritefonction. Donc maintenant, chaque fois que nous invoquons la fonction fwrite, nous n'avons pas à mentionner leio nom du module partout.

Mots-clés à Erlang

Un mot-clé est un mot réservé dans Erlang qui ne doit pas être utilisé à d'autres fins que celles pour lesquelles il a été conçu. Voici la liste des mots-clés à Erlang.

après et et aussi bande
commencer pas bor bsl
bsr bxor Cas capture
cond div fin amusement
si laisser ne pas de
ou ou sinon recevoir rem
essayer quand xor

Commentaires à Erlang

Les commentaires sont utilisés pour documenter votre code. Les commentaires sur une seule ligne sont identifiés à l'aide du%symbole à n'importe quelle position de la ligne. Voici un exemple pour le même -

Exemple

% hello world program
-module(helloworld).
% import function used to import the io module
-import(io,[fwrite/1]).
% export function used to ensure the start function can be accessed.
-export([start/0]).

start() ->
   fwrite("Hello, world!\n").

Le shell Erlang est utilisé pour tester les expressions. Par conséquent, les tests peuvent être effectués très facilement dans le shell avant qu'il ne soit réellement testé dans l'application elle-même.

L'exemple suivant montre comment l'expression d'addition peut être utilisée dans le shell. Ce qu'il faut noter ici, c'est que l'expression doit se terminer par le délimiteur point (.).

Une fois la commande exécutée, le shell imprime une autre invite, cette fois pour la commande numéro 2 (car le numéro de commande augmente à chaque fois qu'une nouvelle commande est entrée).

Les fonctions suivantes sont les plus couramment utilisées dans le shell Erlang.

  • b() - Imprime les liaisons de variables actuelles.

  • Syntax - b ().

  • For example- Voici un exemple d'utilisation de la fonction. D'abord une variable appeléeStr est défini, qui a la valeur abcd. ensuiteb() est utilisé pour afficher toutes les variables liées.

  • f() - Supprime toutes les liaisons de variables actuelles.

  • Syntax - f ().

  • For example- Voici un exemple d'utilisation de la fonction. Tout d'abord, une variable appelée Str est définie qui a la valeur abcd. Le f () est ensuite utilisé pour supprimer la liaison de variable Str. Le b () est ensuite appelé pour s'assurer que la liaison a été supprimée avec succès.

  • f(x) - Supprime la liaison pour une variable particulière.

  • Syntax- f (x). Où, x - est la variable pour laquelle la liaison doit être supprimée.

  • For example- Voici un exemple d'utilisation de la fonction. Tout d'abord, une variable appelée Str et Str1 sont définies. Le f (Str) est ensuite utilisé pour supprimer la liaison de variable Str. Le b () est ensuite appelé pour s'assurer que la liaison a été supprimée avec succès.

  • h() - Imprime la liste historique de toutes les commandes exécutées dans le shell.

  • Syntax - h ().

  • For example - Un exemple de la commande h (), qui imprime l'historique des commandes exécutées dans le shell, est illustré dans la capture d'écran suivante.

  • history(N)- Définit le nombre de commandes précédentes à conserver dans la liste d'historique sur N. Le numéro précédent est renvoyé. Le nombre par défaut est 20.

  • Syntax- histoire (N). Où, N - est le nombre auquel la liste d'historique des commandes doit être limitée.

  • For example - Un exemple de la commande historique (N) est illustré dans la capture d'écran suivante.

  • e(N)- Répète la commande N, si N est positif. S'il est négatif, la N ième commande précédente est répétée (c'est-à-dire que e (-1) répète la commande précédente).

  • Syntax- e (N). Où, N - est la commande à la N ième position dans la liste.

  • For example- Un exemple de la commande e (N) est illustré ci-dessous. Puisque nous avons exécuté la commande e (-1), elle exécutera la commande précédente qui était history (5).

Dans n'importe quel langage de programmation, vous devez utiliser plusieurs variables pour stocker différents types d'informations. Les variables ne sont rien d'autre que des emplacements de mémoire réservés pour stocker des valeurs. Cela signifie que lorsque vous créez une variable, vous réservez de l'espace dans la mémoire pour stocker la valeur associée à cette variable.

Vous pouvez souhaiter stocker des informations de différents types de données comme une chaîne, un caractère, un caractère large, un entier, une virgule flottante, une valeur booléenne, etc. En fonction du type de données d'une variable, le système d'exploitation alloue de la mémoire et décide de ce qui peut être stocké dans le fichier réservé Mémoire.

Types de données intégrés

Erlang propose une grande variété de types de données intégrés. Voici une liste des types de données qui sont définis dans Erlang -

  • Number - Dans Erlang, il existe 2 types de littéraux numériques qui sont des entiers et des flottants.

  • Atom- Un atome est un littéral, une constante avec un nom. Un atome doit être placé entre guillemets simples (') s'il ne commence pas par une lettre minuscule ou s'il contient d'autres caractères que des caractères alphanumériques, un trait de soulignement (_) ou @.

  • Boolean - Les types de données booléens dans Erlang sont les deux atomes réservés: vrai et faux.

  • Bit String - Une chaîne de bits est utilisée pour stocker une zone de mémoire non typée.

  • Tuple- Un tuple est un type de données composé avec un nombre fixe de termes. Chaque terme du tuple est appelé en tant qu'élément. On dit que le nombre d'éléments est la taille du tuple.

  • Map- Une carte est un type de données composé avec un nombre variable d'associations clé-valeur. Chaque association clé-valeur de la carte est appelée une paire d'associations. Les parties clé et valeur de la paire sont appelées éléments. On dit que le nombre de paires d'associations est la taille de la carte.

  • List- Une liste est un type de données composé avec un nombre variable de termes. Chaque terme de la liste est appelé un élément. On dit que le nombre d'éléments est la longueur de la liste.

Note- Vous serez surpris de voir que vous ne pouvez voir le type String nulle part dans la liste ci-dessus. C'est parce qu'il n'y a pas de type de données chaîne exclusivement défini dans Erlang. Mais nous verrons comment nous pouvons travailler avec des chaînes dans un chapitre suivant.

Voici des exemples d'utilisation de chaque type de données. Là encore, chaque type de données sera discuté en détail dans les chapitres suivants. Ceci est juste pour vous familiariser avec une brève description des types de données mentionnés ci-dessus.

Nombre

Un exemple d'utilisation du type de données numérique est présenté dans le programme suivant. Ce programme montre l'ajout de 2 entiers.

Example

-module(helloworld).
-export([start/0]).

start() ->
   io:fwrite("~w",[1+1]).

La sortie du programme ci-dessus sera -

Output

2

Atome

Les atomes doivent commencer par une lettre minuscule et peuvent contenir des caractères minuscules et majuscules, des chiffres, des traits de soulignement (_) et le signe «at» (@). Nous pouvons également mettre un atome entre guillemets simples.

Un exemple de la façon dont le type de données atom peut être utilisé est présenté dans le programme suivant. Dans ce programme, nous créons un atome qui s'appelle atom1.

Example

-module(helloworld).
-export([start/0]).

start() ->
   io:fwrite(atom1).

La sortie du programme ci-dessus sera -

Output

atom1

Booléen

Un exemple de la façon dont le type de données booléen peut être utilisé est présenté dans le programme suivant. Cet exemple effectue une comparaison entre 2 entiers et imprime le booléen résultant sur la console.

Example

-module(helloworld).
-export([start/0]).

start() ->
   io:fwrite(2 =< 3).

La sortie du programme ci-dessus sera -

Output

true

Chaîne de bits

Un exemple de la façon dont le type de données Bit String peut être utilisé est présenté dans le programme suivant. Ce programme définit une chaîne de bits composée de 2 bits. lebinary_to_list est une fonction intégrée définie dans Erlang qui peut être utilisée pour convertir une chaîne de bits en une liste.

Example

-module(helloworld).
-export([start/0]).

start() ->
   Bin1 = <<10,20>>,
   X = binary_to_list(Bin1),
   io:fwrite("~w",[X]).

La sortie du programme ci-dessus sera -

Output

[10,20]

Tuple

Un exemple de la façon dont le type de données Tuple peut être utilisé est illustré dans le programme suivant.

Ici, nous définissons un Tuple Pqui a 3 termes. letuple_size est une fonction intégrée définie dans Erlang, qui peut être utilisée pour déterminer la taille du tuple.

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   P = {john,24,{june,25}} , 
   io:fwrite("~w",[tuple_size(P)]).

La sortie du programme ci-dessus sera -

Output

3

Carte

Un exemple de la façon dont le type de données Carte peut être utilisé est présenté dans le programme suivant.

Ici, nous définissons un Map M1qui a 2 mappages. lemap_size est une fonction intégrée définie dans Erlang, qui peut être utilisée pour déterminer la taille de la carte.

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   M1 = #{name=>john,age=>25}, 
   io:fwrite("~w",[map_size(M1)]).

La sortie du programme ci-dessus sera -

Output

2

liste

Un exemple de la façon dont le type de données Liste peut être utilisé est présenté dans le programme suivant.

Ici, nous définissons un List Lqui a 3 articles. La longueur est une fonction intégrée définie dans Erlang, qui peut être utilisée pour déterminer la taille de la liste.

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   L = [10,20,30] , 
   io:fwrite("~w",[length(L)]).

La sortie du programme ci-dessus sera -

Output

3

Dans Erlang, toutes les variables sont liées par l'instruction '='. Toutes les variables doivent commencer par le caractère majuscule. Dans d'autres langages de programmation, le signe «=» est utilisé pour l'affectation, mais pas dans le cas d'Erlang. Comme indiqué, les variables sont définies à l'aide de l'instruction «=».

Une chose clé à noter dans Erlang est que les variables sont immuables, ce qui signifie que pour que la valeur de la variable change, elle doit être détruite et recréée à nouveau.

Les variables de base suivantes d'Erlang sont expliquées dans le dernier chapitre -

  • Numbers- Ceci est utilisé pour représenter un entier ou un flottant. Un exemple est 10.

  • Boolean - Cela représente une valeur booléenne qui peut être vraie ou fausse.

  • Bit String- Une chaîne de bits est utilisée pour stocker une zone de mémoire non typée. Un exemple est << 40,50 >>.

  • Tuple- Un tuple est un type de données composé avec un nombre fixe de termes. Un exemple est {40,50}.

  • Map- Une carte est un type de données composé avec un nombre variable d'associations clé-valeur. Chaque association clé-valeur de la carte est appelée une paire d'associations. Un exemple est {type => personne, age => 25}.

  • List- Une liste est un type de données composé avec un nombre variable de termes. Un exemple est [40,40].

Déclarations variables

La syntaxe générale de la définition d'une variable est la suivante -

Syntaxe

var-name = var-value

Où,

  • var-name - C'est le nom de la variable.

  • var-value - C'est la valeur liée à la variable.

Voici un exemple de déclaration de variable -

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   X = 40, 
   Y = 50, 
   Result = X + Y, 
   io:fwrite("~w",[Result]).

Dans l'exemple ci-dessus, nous avons 2 variables, l'une est X qui est liée à la valeur 40 et la suivante est Y qui est liée à la valeur de 50. Une autre variable appelée Result est liée à l'addition de X et Y.

La sortie du programme ci-dessus sera -

Production

90

Nommer les variables

Comme indiqué, les noms de variables doivent commencer par des majuscules. Prenons un exemple de variable déclarée en minuscules.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   X = 40, 
   Y = 50, 
   result = X + Y, 
   io:fwrite("~w",[Result]).

Si vous essayez de compiler le programme ci-dessus, vous obtiendrez l'erreur de compilation suivante.

Production

helloworld.erl:8: variable 'Result' is unbound

Deuxièmement, toutes les variables ne peuvent être affectées qu'une seule fois. Prenons un exemple d'affectation d'une variable plus d'une fois.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   X = 40, 
   Y = 50, 
   X = 60, 
   io:fwrite("~w",[X]).

Si vous essayez de compiler le programme ci-dessus, vous recevrez l'erreur de compilation suivante.

Production

helloworld.erl:6: Warning: variable 'Y' is unused
helloworld.erl:7: Warning: no clause will ever match
helloworld.erl:7: Warning: the guard for this clause evaluates to 'false'

Variables d'impression

Dans cette section, nous verrons comment utiliser les différentes fonctions d'impression des variables.

Utilisation de la fonction io: fwrite

Vous auriez vu ceci (io: fwrite) utilisé dans tous les programmes ci-dessus. lefwrite La fonction fait partie du module 'io' ou Erlang, qui peut être utilisé pour sortir la valeur des variables dans le programme.

L'exemple suivant montre quelques paramètres supplémentaires qui peuvent être utilisés avec l'instruction fwrite.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   X = 40.00, 
   Y = 50.00, 
   io:fwrite("~f~n",[X]), 
   io:fwrite("~e",[Y]).

La sortie du programme ci-dessus sera -

Production

40.000000
5.00000e+1

Les pointeurs suivants doivent être notés sur le programme ci-dessus.

  • ~ - Ce caractère symbolise qu'un certain formatage doit être effectué pour la sortie.

  • ~f- L'argument est un flottant qui s'écrit [-] ddd.ddd, où la précision est le nombre de chiffres après la virgule décimale. La précision par défaut est 6 et ne peut pas être inférieure à 1.

  • ~n - C'est pour println à une nouvelle ligne.

  • ~e- L'argument est un flottant qui s'écrit [-] d.ddde + -ddd, où la précision est le nombre de chiffres écrits. La précision par défaut est 6 et ne peut pas être inférieure à 2.

Un opérateur est un symbole qui indique au compilateur d'effectuer des manipulations mathématiques ou logiques spécifiques.

Erlang a le type d'opérateurs suivant -

  • Opérateurs arithmétiques
  • Opérateurs relationnels
  • Opérateurs logiques
  • Opérateurs au niveau du bit

Opérateurs arithmétiques

Le langage Erlang prend en charge les opérateurs arithmétiques normaux comme n'importe quel langage. Voici les opérateurs arithmétiques disponibles dans Erlang.

Afficher des exemples

Opérateur La description Exemple
+ Ajout de deux opérandes 1 + 2 donnera 3
- Soustrait le deuxième opérande du premier 1 - 2 donnera -1
* Multiplication des deux opérandes 2 * 2 donnera 4
/ Division du numérateur par dénominateur 2/2 donnera 1
rem Reste de la division du premier nombre par le second 3 rem 2 donnera 1
div Le composant div effectuera la division et retournera le composant entier. 3 div 2 donnera 1

Opérateurs relationnels

Les opérateurs relationnels permettent la comparaison d'objets. Voici les opérateurs relationnels disponibles dans Erlang.

Afficher des exemples

Opérateur La description Exemple
== Teste l'égalité entre deux objets 2 = 2 donnera vrai
/ = Teste la différence entre deux objets 3 / = 2 donnera vrai
< Vérifie si l'objet gauche est inférieur à l'opérande droit. 2 <3 donnera vrai
= < Vérifie si l'objet gauche est inférieur ou égal à l'opérande droit. 2 = <3 donnera vrai
> Vérifie si l'objet gauche est supérieur à l'opérande droit. 3> 2 donnera vrai
> = Vérifie si l'objet gauche est supérieur ou égal à l'opérande droit. 3> = 2 donnera vrai

Opérateurs logiques

Ces opérateurs logiques sont utilisés pour évaluer les expressions booléennes. Voici les opérateurs logiques disponibles dans Erlang.

Afficher des exemples

Opérateur La description Exemple
ou Il s'agit de l'opérateur logique «ou» vrai ou vrai donnera vrai
et Il s'agit de l'opérateur logique «et» Vrai et faux donneront faux
ne pas C'est l'opérateur logique «non» pas faux donnera vrai
xor Il s'agit de l'opérateur logique «xor» exclusif Vrai x ou faux donnera vrai

Opérateurs au niveau du bit

Erlang fournit quatre opérateurs au niveau du bit. Voici les opérateurs au niveau du bit disponibles dans Erlang.

Afficher des exemples

Sr.No. Opérateur et description
1

band

Il s’agit de l’opérateur «et» au niveau du bit

2

bor

Il s’agit de l’opérateur «ou» au niveau du bit

3

bxor

Il s’agit de l’opérateur «xor» ou exclusif ou au niveau du bit

4

bnot

C'est l'opérateur de négation au niveau du bit

Voici la table de vérité présentant ces opérateurs -

p q p & q p | q p ^ q
0 0 0 0 0
0 1 0 1 1
1 1 1 1 0
1 0 0 1 1

Priorité de l'opérateur

Le tableau suivant présente la priorité des opérateurs pour les opérateurs Erlang par ordre de priorité décroissante ainsi que leur associativité. La priorité et l'associativité des opérateurs sont utilisées pour déterminer l'ordre d'évaluation dans les expressions sans parenthèses.

Les opérateurs Associativité
:
#
bnot, pas
/, *, div, rem, band et Associatif gauche
+, -, bor, bxor ou, xor Associatif gauche
==, / =, = <, <,> =,>

Erlang est un langage de programmation fonctionnel et ce dont il faut se souvenir à propos de tous les langages de programmation fonctionnelle, c'est qu'ils n'offrent aucune construction pour les boucles. Au lieu de cela, la programmation fonctionnelle dépend d'un concept appelé récursivité.

tandis que la mise en œuvre de la déclaration

Puisqu'il n'y a pas d'instruction while directe disponible dans Erlang, il faut utiliser les techniques de récursivité disponibles dans Erlang pour effectuer une implémentation d'instruction while.

Nous allons essayer de suivre la même implémentation de la boucle while que celle suivie dans d'autres langages de programmation. Voici le flux général qui sera suivi.

Regardons un exemple de la façon dont nous pouvons utiliser la récursivité pour implémenter le while boucle à Erlang.

Exemple

-module(helloworld). 
-export([while/1,while/2, start/0]). 

while(L) -> while(L,0). 
while([], Acc) -> Acc;

while([_|T], Acc) ->
   io:fwrite("~w~n",[Acc]), 
   while(T,Acc+1). 
   
   start() -> 
   X = [1,2,3,4], 
   while(X).

Les points clés suivants doivent être notés à propos du programme ci-dessus -

  • Définissez une fonction récursive appelée while qui simulerait l'implémentation de notre boucle while.

  • Entrez une liste de valeurs définies dans la variable X dans notre fonction while à titre d'exemple.

  • La fonction while prend chaque valeur de liste et stocke la valeur intermédiaire dans la variable «Acc».

  • La boucle while est ensuite appelée récursivement pour chaque valeur de la liste.

La sortie du code ci-dessus sera -

Production

0
1
2
3

pour Statement

Puisqu'il n'y a pas de direct for instruction disponible dans Erlang, il faut utiliser les techniques de récursion disponibles dans Erlang pour effectuer une for mise en œuvre de la déclaration.

Nous essaierons de suivre la même implémentation du forboucle comme il est suivi dans d'autres langages de programmation. Voici le flux général qui doit être respecté.

Regardons un exemple de la façon dont nous pouvons utiliser la récursivité pour implémenter le for boucle à Erlang.

Exemple

-module(helloworld). 
-export([for/2,start/0]). 

for(0,_) -> 
   []; 
   
   for(N,Term) when N > 0 -> 
   io:fwrite("Hello~n"), 
   [Term|for(N-1,Term)]. 
   
start() -> 
   for(5,1).

Les points clés suivants doivent être notés à propos du programme ci-dessus -

  • Nous définissons une fonction récursive qui simulerait l'implémentation de notre for loop.

  • Nous utilisons une garde dans la fonction «pour» pour nous assurer que la valeur de N ou la limite est une valeur positive.

  • Nous appelons récursivement la fonction for, en réduisant la valeur de N à chaque récursivité.

La sortie du code ci-dessus sera -

Production

Hello
Hello
Hello
Hello
Hello

Les structures de prise de décision exigent que le programmeur spécifie une ou plusieurs conditions à évaluer ou à tester par le programme, ainsi qu'une ou plusieurs instructions à exécuter si la condition est déterminée comme étant true, et éventuellement d'autres instructions à exécuter si la condition est déterminée false.

Voici la forme générale d'une structure de prise de décision typique trouvée dans la plupart des langages de programmation -

Le langage de programmation Erlang fournit les types suivants d'énoncés de prise de décision.

Sr.No. Déclaration et description
1

Si déclaration

Un if statement se compose d'une expression booléenne suivie d'une ou plusieurs instructions.

2

Expression multiple

le if expression permet également d'évaluer plusieurs expressions à la fois.

3

Instructions si imbriquées

Vous pouvez en utiliser un if ou else if déclaration dans un autre if ou else if déclaration (s).

4

Déclarations de cas

Il peut être utilisé pour exécuter des expressions basées sur la sortie de l'instruction case.

Erlang est connu comme un langage de programmation fonctionnel, par conséquent vous vous attendriez à voir beaucoup d'emphase sur le fonctionnement des fonctions dans Erlang. Ce chapitre couvre tout ce qui peut être fait avec les fonctions d'Erlang.

Définition d'une fonction

La syntaxe d'une déclaration de fonction est la suivante -

Syntaxe

FunctionName(Pattern1… PatternN) ->
Body;

Où,

  • FunctionName - Le nom de la fonction est un atome.

  • Pattern1… PatternN- Chaque argument est un modèle. Le nombre d'arguments N est l'arité de la fonction. Une fonction est définie de manière unique par le nom du module, le nom de la fonction et l'arité. Autrement dit, deux fonctions avec le même nom et dans le même module, mais avec des arités différentes sont deux fonctions différentes.

  • Body - Un corps de clause se compose d'une séquence d'expressions séparées par des virgules (,):

Le programme suivant est un exemple simple d'utilisation de fonctions -

Exemple

-module(helloworld). 
-export([add/2,start/0]). 

add(X,Y) -> 
   Z = X+Y, 
   io:fwrite("~w~n",[Z]). 
   
start() -> 
   add(5,6).

Les pointeurs suivants doivent être notés sur le programme ci-dessus -

  • Nous définissons deux fonctions, l'une s'appelle add qui prend 2 paramètres et l'autre est le start fonction.

  • Les deux fonctions sont définies avec la fonction d'exportation. Si nous ne le faisons pas, nous ne pourrons pas utiliser la fonction.

  • Une fonction peut être appelée dans une autre. Ici, nous appelons la fonction add à partir de la fonction de démarrage.

La sortie du programme ci-dessus sera -

Production

11

Fonctions anonymes

Une fonction anonyme est une fonction à laquelle aucun nom ne lui est associé. Erlang a la possibilité de définir des fonctions anonymes. Le programme suivant est un exemple de fonction anonyme.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   Fn = fun() -> 
      io:fwrite("Anonymous Function") end, 
   Fn().

Les points suivants doivent être notés à propos de l'exemple ci-dessus -

  • La fonction anonyme est définie avec le fun() mot-clé.

  • La fonction est affectée à une variable appelée Fn.

  • La fonction est appelée via le nom de la variable.

La sortie du programme ci-dessus sera -

Production

Anonymous Function

Fonctions avec plusieurs arguments

Les fonctions Erlang peuvent être définies avec zéro ou plusieurs paramètres. La surcharge de fonction est également possible, dans laquelle vous pouvez définir une fonction avec le même nom plusieurs fois, à condition qu'elle ait un nombre différent de paramètres.

Dans l'exemple suivant, la démo de fonction est définie avec plusieurs arguments pour chaque définition de fonction.

Exemple

-module(helloworld). 
-export([add/2,add/3,start/0]). 

add(X,Y) -> 
   Z = X+Y, 
   io:fwrite("~w~n",[Z]). 
   
add(X,Y,Z) -> 
   A = X+Y+Z, 
   io:fwrite("~w~n",[A]). 
 
start() ->
   add(5,6), 
   add(5,6,6).

Dans le programme ci-dessus, nous définissons la fonction d'ajout deux fois. Mais la définition de la première fonction d'ajout prend deux paramètres et la seconde prend trois paramètres.

La sortie du programme ci-dessus sera -

Production

11
17

Fonctions avec séquences de garde

Les fonctions d'Erlang ont également la capacité d'avoir des séquences de garde. Ce ne sont que des expressions qui, lorsqu'elles sont évaluées à true, entraîneront l'exécution de la fonction.

La syntaxe d'une fonction avec une séquence de garde est indiquée dans le programme suivant.

Syntaxe

FunctionName(Pattern1… PatternN) [when GuardSeq1]->
Body;

Où,

  • FunctionName - Le nom de la fonction est un atome.

  • Pattern1… PatternN- Chaque argument est un modèle. Le nombre d'arguments N est l'arité de la fonction. Une fonction est définie de manière unique par le nom du module, le nom de la fonction et l'arité. Autrement dit, deux fonctions avec le même nom et dans le même module, mais avec des arités différentes sont deux fonctions différentes.

  • Body - Un corps de clause se compose d'une séquence d'expressions séparées par une virgule (,).

  • GuardSeq1 - C'est l'expression qui est évaluée lorsque la fonction est appelée.

Le programme suivant est un exemple simple d'utilisation d'une fonction avec une séquence de garde.

Exemple

-module(helloworld). 
-export([add/1,start/0]). 

add(X) when X>3 -> 
   io:fwrite("~w~n",[X]). 

start() -> 
   add(4).

La sortie du programme ci-dessus est -

Production

4

Si la fonction d'ajout a été appelée comme add(3), le programme provoquera une erreur.

Les modules sont un ensemble de fonctions regroupées dans un seul fichier, sous un seul nom. De plus, toutes les fonctions d'Erlang doivent être définies dans des modules.

La plupart des fonctionnalités de base telles que les opérateurs arithmétiques, logiques et booléens sont déjà disponibles car les modules par défaut sont chargés lors de l'exécution d'un programme. Toutes les autres fonctions définies dans un module que vous utiliserez doivent être appelées avec le formulaireModule:Function (Arguments).

Définition d'un module

Avec un module, vous pouvez déclarer deux types de choses: des fonctions et des attributs. Les attributs sont des métadonnées décrivant le module lui-même, comme son nom, les fonctions qui devraient être visibles du monde extérieur, l'auteur du code, etc. Ce type de métadonnées est utile car il donne des indications au compilateur sur la façon dont il doit faire son travail, et aussi parce qu'il permet aux gens de récupérer des informations utiles à partir du code compilé sans avoir à consulter la source.

La syntaxe d'une déclaration de fonction est la suivante -

Syntaxe

-module(modulename)

Où, modulenameest le nom du module. Cela doit être la première ligne du code dans le module.

Le programme suivant montre un exemple de module appelé helloworld.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   io:fwrite("Hello World").

La sortie du programme ci-dessus est -

Production

Hello World

Attributs du module

Un attribut de module définit une certaine propriété d'un module. Un attribut de module se compose d'une balise et d'une valeur.

La syntaxe générale d'un attribut est -

Syntaxe

-Tag(Value)

Un exemple de la façon dont l'attribut peut être utilisé est montré dans le programme suivant -

Exemple

-module(helloworld). 
-author("TutorialPoint"). 
-version("1.0"). 
-export([start/0]). 

start() -> 
   io:fwrite("Hello World").

Le programme ci-dessus définit 2 attributs personnalisés appelés auteur et version qui contiennent respectivement l'auteur du programme et le numéro de version du programme.

La sortie du programme ci-dessus est -

Production

Hello World

Attributs pré-construits

Erlang a quelques attributs pré-construits qui peuvent être attachés aux modules. Jetons un coup d'œil à eux.

Exportation

L'attribut exports prendra une liste de fonctions et d'arité à exporter pour la consommation par d'autres modules. Il définira l'interface du module. Nous l'avons déjà vu dans tous nos exemples précédents.

Syntaxe

export([FunctionName1/FunctionArity1,.,FunctionNameN/FunctionArityN])

Où,

  • FunctionName - C'est le nom de la fonction dans le programme.

  • FunctionArity - C'est le nombre de paramètres associés à la fonction.

Exemple

-module(helloworld). 
-author("TutorialPoint"). 
-version("1.0"). 
-export([start/0]). 

start() -> 
   io:fwrite("Hello World").

La sortie du programme ci-dessus sera -

Production

Hello World

Importer

L'attribut import est utilisé pour importer des fonctions d'un autre module pour les utiliser en local.

Syntaxe

-import (modulename , [functionname/parameter]).

Où,

  • Modulename - C'est le nom du module qui doit être importé.

  • functionname/parameter - la fonction dans le module qui doit être importée.

Exemple

-module(helloworld). 
-import(io,[fwrite/1]). 
-export([start/0]). 

start() -> 
   fwrite("Hello, world!\n").

Dans le code ci-dessus, nous utilisons le mot-clé import pour importer la bibliothèque 'io' et plus particulièrement la fonction fwrite. Ainsi, chaque fois que nous invoquons la fonction fwrite, nous n'avons pas à mentionner le nom du module io partout.

La sortie du programme ci-dessus sera -

Production

Hello, world!

La récursivité est une partie importante d'Erlang. Voyons d'abord comment nous pouvons implémenter une récursion simple en implémentant le programme factoriel.

Exemple

-module(helloworld). 
-export([fac/1,start/0]). 

fac(N) when N == 0 -> 1; 
fac(N) when N > 0 -> N*fac(N-1). 

start() -> 
   X = fac(4), 
   io:fwrite("~w",[X]).

Les choses suivantes doivent être notées à propos du programme ci-dessus -

  • Nous définissons d'abord une fonction appelée fac (N).

  • Nous sommes capables de définir la fonction récursive en appelant fac (N) récursivement.

La sortie du programme ci-dessus est -

Production

24

Approche pratique de la récursivité

Dans cette section, nous allons comprendre en détail les différents types de récursions et son utilisation à Erlang.

Récurrence de longueur

Une approche plus pratique de la récursivité peut être vue avec un exemple simple qui est utilisé pour déterminer la longueur d'une liste. Une liste peut avoir plusieurs valeurs telles que [1,2,3,4]. Utilisons la récursivité pour voir comment nous pouvons obtenir la longueur d'une liste.

Example

-module(helloworld). 
-export([len/1,start/0]). 

len([]) -> 0; 
len([_|T]) -> 1 + len(T). 

start() -> 
   X = [1,2,3,4], 
   Y = len(X), 
   io:fwrite("~w",[Y]).

Les choses suivantes doivent être notées à propos du programme ci-dessus -

  • La première fonction len([]) est utilisé pour la condition de cas particulier si la liste est vide.

  • le [H|T] motif à comparer avec des listes d'un ou plusieurs éléments, comme une liste de longueur un sera défini comme [X|[]] et une liste de longueur deux sera définie comme [X|[Y|[]]]. Notez que le deuxième élément est une liste elle-même. Cela signifie que nous devons seulement compter le premier et que la fonction peut s'appeler sur le deuxième élément. Étant donné que chaque valeur dans une liste compte pour une longueur de 1.

La sortie du programme ci-dessus sera -

Output

4

Récurrence de la queue

Pour comprendre le fonctionnement de la récursivité de queue, comprenons comment fonctionne le code suivant de la section précédente.

Syntax

len([]) -> 0; 
len([_|T]) -> 1 + len(T).

La réponse à 1 + len (Rest) nécessite la réponse de len (Rest) pour être trouvée. La fonction len (Rest) elle-même avait alors besoin du résultat d'un autre appel de fonction pour être trouvé. Les ajouts seraient empilés jusqu'à ce que le dernier soit trouvé, et alors seulement le résultat final serait calculé.

La récursivité de queue vise à éliminer cet empilement d'opérations en les réduisant au fur et à mesure qu'ils se produisent.

Pour y parvenir, nous aurons besoin de conserver une variable temporaire supplémentaire en tant que paramètre dans notre fonction. La variable temporaire précitée est parfois appelée accumulateur et sert de lieu de stockage des résultats de nos calculs au fur et à mesure de leur déroulement afin de limiter la croissance de nos appels.

Regardons un exemple de récursion de queue -

Example

-module(helloworld).
-export([tail_len/1,tail_len/2,start/0]). 

tail_len(L) -> tail_len(L,0). 
tail_len([], Acc) -> Acc; 
tail_len([_|T], Acc) -> tail_len(T,Acc+1). 

start() -> 
   X = [1,2,3,4], 
   Y = tail_len(X), 
   io:fwrite("~w",[Y]).

La sortie du programme ci-dessus est -

Output

4

Dupliquer

Regardons un exemple de récursivité. Cette fois-ci, écrivons une fonction qui prend un entier comme premier paramètre, puis tout autre terme comme deuxième paramètre. Il créera alors une liste d'autant de copies du terme que spécifié par l'entier.

Regardons à quoi ressemblerait un exemple de ceci -

-module(helloworld). 
-export([duplicate/2,start/0]). 

duplicate(0,_) -> 
   []; 
duplicate(N,Term) when N > 0 ->
   io:fwrite("~w,~n",[Term]),
   [Term|duplicate(N-1,Term)]. 
start() -> 
   duplicate(5,1).

La sortie du programme ci-dessus sera -

Production

1,
1,
1,
1,
1,

Annulation de liste

Il n'y a pas de limites auxquelles vous pouvez utiliser la récursivité dans Erlang. Voyons maintenant rapidement comment inverser les éléments d'une liste en utilisant la récursivité. Le programme suivant peut être utilisé pour ce faire.

Exemple

-module(helloworld). 
-export([tail_reverse/2,start/0]). 

tail_reverse(L) -> tail_reverse(L,[]).

tail_reverse([],Acc) -> Acc; 
tail_reverse([H|T],Acc) -> tail_reverse(T, [H|Acc]).

start() -> 
   X = [1,2,3,4], 
   Y = tail_reverse(X), 
   io:fwrite("~w",[Y]).

La sortie du programme ci-dessus sera -

Production

[4,3,2,1]

Les choses suivantes doivent être notées à propos du programme ci-dessus -

  • Nous utilisons à nouveau le concept de variables temporaires pour stocker chaque élément de la liste dans une variable appelée Acc.

  • Nous appelons alors tail_reverse récursivement, mais cette fois-ci, nous nous assurons que le dernier élément est mis en premier dans la nouvelle liste.

  • Nous appelons ensuite récursivement tail_reverse pour chaque élément de la liste.

Dans Erlang, il existe 2 types de littéraux numériques qui sont des entiers et des flottants. Voici quelques exemples qui montrent comment les entiers et les flottants peuvent être utilisés dans Erlang.

Integer- Un exemple de la façon dont le type de données numérique peut être utilisé comme un entier est présenté dans le programme suivant. Ce programme montre l'ajout de 2 entiers.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   io:fwrite("~w",[1+1]).

La sortie du programme ci-dessus sera la suivante -

Production

2

Float- Un exemple de la façon dont le type de données numérique peut être utilisé comme un flottant est montré dans le programme suivant. Ce programme montre l'ajout de 2 entiers.

Exemple

-module(helloworld).
-export([start/0]). 

start() -> 
   io:fwrite("~w",[1.1+1.2]).

La sortie du programme ci-dessus sera la suivante -

Production

2.3

Affichage des nombres flottants et exponentiels

Lors de l'utilisation du fwritepour afficher les valeurs vers la console, il existe des paramètres de formatage disponibles qui peuvent être utilisés pour afficher des nombres sous forme de nombres flottants ou exponentiels. Voyons comment nous pouvons y parvenir.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   io:fwrite("~f~n",[1.1+1.2]), 
   io:fwrite("~e~n",[1.1+1.2]).

La sortie du programme ci-dessus sera la suivante -

Production

2.300000
2.30000e+0

Les points clés suivants doivent être notés à propos du programme ci-dessus

  • Lorsque l'option ~ f est spécifiée, cela signifie que l'argument est un flottant qui s'écrit [-]ddd.ddd, où la précision est le nombre de chiffres après la virgule décimale. La précision par défaut est 6.

  • Lorsque l'option ~ e est spécifiée, cela signifie que l'argument est un flottant qui s'écrit [-]d.ddde+-ddd, où la précision est le nombre de chiffres écrits. La précision par défaut est 6.

Fonctions mathématiques pour les nombres

Les fonctions mathématiques suivantes sont disponibles dans Erlang pour les nombres. Notez que toutes les fonctions mathématiques d'Erlang sont présentes dans la bibliothèque mathématique. Ainsi, tous les exemples ci-dessous utiliseront l'instruction import pour importer toutes les méthodes de la bibliothèque mathématique.

Sr.No. Fonctions mathématiques et description
1

péché

Cette méthode renvoie le sinus de la valeur spécifiée.

2

cos

Cette méthode renvoie le cosinus de la valeur spécifiée.

3

bronzer

Cette méthode renvoie la tangente de la valeur spécifiée.

4

un péché

La méthode renvoie l'arc sinus de la valeur spécifiée.

5

acos

La méthode renvoie l'arc cosinus de la valeur spécifiée.

6

un bronzage

La méthode renvoie l'arc tangente de la valeur spécifiée.

sept exp

La méthode renvoie l'exponentielle de la valeur spécifiée.

8

Journal

La méthode renvoie le logarithmique de la valeur spécifiée.

9

abdos

La méthode renvoie la valeur absolue du nombre spécifié.

dix

flotte

La méthode convertit un nombre en valeur flottante.

11

Is_float

La méthode vérifie si un nombre est une valeur flottante.

12

Is_Integer

La méthode vérifie si un nombre est une valeur entière.

Un littéral String est construit en Erlang en plaçant le texte de chaîne entre guillemets. Les chaînes en Erlang doivent être construites en utilisant les guillemets doubles tels que «Hello World».

Voici un exemple d'utilisation des chaînes dans Erlang -

Exemple

-module(helloworld). 
-export([start/0]). 

start() ->
   Str1 = "This is a string", 
   io:fwrite("~p~n",[Str1]).

L'exemple ci-dessus crée une variable de chaîne appelée Str1. La chaîne «Ceci est une chaîne» est affectée à la variable et affichée en conséquence.

La sortie du programme ci-dessus sera -

Production

“This is a string”

Ensuite, nous discuterons des différents operations available for Strings. Notez que pour les opérations de chaînes, vous devez également inclure la bibliothèque de chaînes.

Sr.Non Méthodes de chaîne et description
1

len

La méthode renvoie la longueur d'une chaîne particulière.

2

égal

La méthode renvoie une valeur booléenne indiquant si une chaîne est égale à une autre.

3

concat

La méthode concatène 2 chaînes et renvoie la chaîne concaténée.

4

chr

La méthode renvoie la position d'index d'un caractère dans une chaîne.

5

str

La méthode renvoie la position d'index d'une sous-chaîne dans une chaîne.

6

substr

La méthode renvoie la sous-chaîne de la chaîne d'origine en fonction de la position de départ et du nombre de caractères à partir de la position de départ.

sept

la gauche

La méthode renvoie la sous-chaîne de la chaîne d'origine en fonction de la position de départ et du nombre de caractères à partir de la position de départ.

gauche avec le caractère de fin

La méthode renvoie la sous-chaîne à gauche de la chaîne en fonction du nombre de caractères. Mais avec la possibilité d'inclure un caractère de fin si le nombre est supérieur à la longueur de la chaîne.

Syntaxe

left(str1,number,$character)

Paramètres

  • str1 - Il s'agit de la chaîne dont la sous-chaîne doit être extraite.

  • Number - C'est le nombre de caractères qui doivent être présents dans la sous-chaîne.

  • $Character - Le caractère à inclure comme caractère de fin.

Valeur de retour

Renvoie la sous-chaîne de la chaîne d'origine en fonction du côté gauche de la chaîne et du nombre.

Par exemple

-module(helloworld). 
-import(string,[left/3]). 
-export([start/0]). 

start() -> 
   Str1 = "hello", 
   Str2 = left(Str1,10,$.), 
   io:fwrite("~p~n",[Str2]).

Production

Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant.

"hello....."

droite

La méthode renvoie la sous-chaîne à droite de la chaîne en fonction du nombre de caractères.

Syntaxe

right(str1,number)

Paramètres

  • str1 - Il s'agit de la chaîne dont la sous-chaîne doit être extraite.

  • Number - C'est le nombre de caractères qui doivent être présents dans la sous-chaîne.

Valeur de retour

Renvoie la sous-chaîne de la chaîne d'origine en fonction du côté droit de la chaîne et du nombre.

Par exemple

-module(helloworld). 
-import(string,[right/2]). 
-export([start/0]). 

start() -> 
   Str1 = "hello World", 
   Str2 = right(Str1,2), 
   io:fwrite("~p~n",[Str2]).

Production

Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant.

“ld”

à droite avec le caractère de fin

La méthode retourne la sous-chaîne à droite de la chaîne en fonction du nombre de caractères. Mais avec la possibilité d'inclure un caractère de fin si le nombre est supérieur à la longueur de la chaîne.

Syntaxe

right(str1,number,$character)

Paramètres

  • str1 - Il s'agit de la chaîne dont la sous-chaîne doit être extraite.

  • Number - C'est le nombre de caractères qui doivent être présents dans la sous-chaîne.

  • $Character - Le caractère à inclure comme caractère de fin.

Valeur de retour

Renvoie la sous-chaîne de la chaîne d'origine en fonction du côté droit de la chaîne et du nombre.

Par exemple

-module(helloworld). 
-import(string,[right/3]). 
-export([start/0]). 

start() -> 
   Str1 = "hello", 
   Str2 = right(Str1,10,$.), 
   io:fwrite("~p~n",[Str2]).

Production

Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant.

".....hello"

baisser

La méthode renvoie la chaîne en minuscules.

Syntaxe

to_lower(str1)

Paramètres

  • str1 - C'est la chaîne à partir de laquelle doit être convertie en minuscules.

Valeur de retour

Renvoie la chaîne en minuscules.

Par exemple

-module(helloworld). 
-import(string,[to_lower/1]). 
-export([start/0]). 

start() -> 
   Str1 = "HELLO WORLD", 
   Str2 = to_lower(Str1), 
   io:fwrite("~p~n",[Str2]).

Production

Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant.

"hello world"

to_upper

La méthode renvoie la chaîne en majuscules.

Syntaxe

to_upper(str1)

Paramètres

  • str1 - C'est la chaîne à partir de laquelle doit être convertie en majuscules.

  • Return Value - Renvoie la chaîne en majuscules.

Par exemple

-module(helloworld). 
-import(string,[to_upper/1]). 
-export([start/0]). 

start() -> 
   Str1 = "hello world", 
   Str2 = to_upper(Str1), 
   io:fwrite("~p~n",[Str2]).

Production

Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant.

"HELLO WORLD"

sub_string

Renvoie une sous-chaîne de String, commençant à la position Start jusqu'à la fin de la chaîne, ou jusqu'à et y compris la position Stop.

Syntaxe

sub_string(str1,start,stop)

Paramètres

  • str1 - Il s'agit de la chaîne à partir de laquelle la sous-chaîne doit être renvoyée.

  • start - C'est la position de départ de la sous-chaîne

  • stop - C'est la position d'arrêt de la sous-chaîne

Valeur de retour

Renvoie une sous-chaîne de String, commençant à la position Start jusqu'à la fin de la chaîne, ou jusqu'à et y compris la position Stop.

Par exemple

-module(helloworld). 
-import(string,[sub_string/3]). 
-export([start/0]). 

start() -> 
   Str1 = "hello world", 
   Str2 = sub_string(Str1,1,5), 
   io:fwrite("~p~n",[Str2]).

Production

Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant.

"hello"

La liste est une structure utilisée pour stocker une collection d'éléments de données. Dans Erlang, les listes sont créées en plaçant les valeurs entre crochets.

Voici un exemple simple de création d'une liste de nombres à Erlang.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   Lst1 = [1,2,3], 
   io:fwrite("~w~n",[Lst1]).

La sortie de l'exemple ci-dessus sera -

Production

[1 2 3]

Parlons maintenant de la various methods available for Lists. Notez que la bibliothèque de listes doit être importée pour que ces méthodes fonctionnent.

Sr.Non Méthode et description
1

tout

Renvoie true si Pred (Elem) renvoie true pour tous les éléments Elem de List, sinon false.

2

tout

Renvoie true si Pred (Elem) renvoie true pour au moins un élément Elem dans List.

3

ajouter

Renvoie une nouvelle liste List3 qui est constituée des éléments de List1 suivis des éléments de List2.

4

effacer

Supprime un élément de la liste et renvoie une nouvelle liste.

5

droplast

Supprime le dernier élément d'une liste.

6

dupliquer

Renvoie une liste qui contient N copies du terme Elem

sept

dernier

Renvoie le dernier élément de la liste

8

max

Renvoie l'élément de la liste qui a la valeur maximale.

9

membre

Vérifie si un élément est présent dans la liste ou non.

dix

min

Renvoie l'élément de la liste qui a la valeur minimale.

11

fusionner

Renvoie la liste triée formée par la fusion de toutes les sous-listes de ListOfLists.

12

nième

Renvoie le Nième élément de List.

13

nthtail

Renvoie la Nième queue de la liste.

14

inverser

Inverse une liste d'éléments.

15

Trier

Trie une liste d'éléments.

16

sous-liste

Renvoie une sous-liste d'éléments.

17

somme

Renvoie la somme des éléments de la liste.

Erlang fournit un certain nombre de méthodes lors de l'utilisation d'E / S. Il a des classes plus faciles pour fournir les fonctionnalités suivantes pour les fichiers -

  • Lecture de fichiers
  • Écriture dans des fichiers
  • Voir si un fichier est un fichier ou un répertoire

Méthodes d'opération de fichier dans Erlang

Explorons certaines des opérations sur les fichiers qu'Erlang a à offrir. Pour les besoins de ces exemples, nous allons supposer qu'il existe un fichier appeléNewFile.txt qui contient les lignes de texte suivantes

Example1

Example2

Example3

Ce fichier sera utilisé pour les opérations de lecture et d'écriture dans les exemples suivants.

Lecture du contenu d'un fichier une ligne à la fois

Les opérations générales sur les fichiers sont effectuées en utilisant les méthodes disponibles dans la bibliothèque de fichiers. Pour la lecture des fichiers, nous devons d'abord utiliser l'opération d'ouverture, puis utiliser l'opération de lecture qui est disponible dans le cadre de la bibliothèque de fichiers. Voici la syntaxe de ces deux méthodes.

Syntaxe

  • Ouverture d'un fichier - Ouvrir (Fichier, Mode)
  • Lecture d'un fichier - lecture (FileHandler, NumberofBytes)

Paramètres

  • File - C'est l'emplacement du fichier qui doit être ouvert.

  • Mode - C'est le mode dans lequel le fichier doit être ouvert.

Voici quelques-uns des modes disponibles -

  • Read - Le fichier, qui doit exister, est ouvert en lecture.

  • Write- Le fichier est ouvert pour l'écriture. Il est créé s'il n'existe pas. Si le fichier existe et si l'écriture n'est pas combinée avec la lecture, le fichier sera tronqué.

  • Append- Le fichier sera ouvert pour l'écriture, et il sera créé s'il n'existe pas. Chaque opération d'écriture dans un fichier ouvert avec append aura lieu à la fin du fichier.

  • Exclusive- Le fichier, lorsqu'il est ouvert pour l'écriture, est créé s'il n'existe pas. Si le fichier existe, open retournera {error, exist}.

  • FileHandler- Ceci est le handle d'un fichier. Cette poignée est celle qui serait retournée lorsque lefile:open l'opération est utilisée.

  • NumberofByte - Il s'agit du nombre d'octets d'informations à lire dans le fichier.

Valeur de retour

  • Open(File,Mode) - Renvoie un handle vers le fichier, si l'opération réussit.

  • read(FileHandler,NumberofBytes) - Renvoie les informations de lecture demandées à partir du fichier.

Par exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   {ok, File} = file:open("Newfile.txt",[read]),
   Txt = file:read(File,1024 * 1024), 
   io:fwrite("~p~n",[Txt]).

Output - Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant.

Example1

Voyons maintenant quelques autres méthodes disponibles pour les opérations sur les fichiers -

Sr.No. Méthode et description
1

file_read

Disponible pour permettre la lecture de tout le contenu d'un fichier à la fois.

2

écrire

Utilisé pour écrire le contenu dans un fichier.

3

copie

utilisé pour faire une copie d'un fichier existant.

4

effacer

Cette méthode est utilisée pour supprimer un fichier existant.

5

list_dir

Cette méthode est utilisée pour lister le contenu d'un répertoire particulier.

6

make_dir

Cette méthode est utilisée pour créer un nouveau répertoire.

sept

Renommer

Cette méthode est utilisée pour renommer un fichier existant.

8

taille du fichier

Cette méthode est utilisée pour déterminer la taille du fichier.

9

is_file

Cette méthode est utilisée pour déterminer si un fichier est bien un fichier.

dix

is_dir

Cette méthode est utilisée pour déterminer si un répertoire est effectivement un répertoire.

Un atome est un littéral, une constante avec un nom. Un atome doit être placé entre guillemets simples (') s'il ne commence pas par une lettre minuscule ou s'il contient d'autres caractères que des caractères alphanumériques, un trait de soulignement (_) ou @.

Le programme suivant est un exemple de la façon dont les atomes peuvent être utilisés dans Erlang. Ce programme déclare respectivement 3 atomes, atom1, atom_1 et 'atom 1'. Ainsi, vous pouvez voir les différentes façons dont un atome peut être déclaré.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   io:fwrite(atom1), 
   io:fwrite("~n"), 
   io:fwrite(atom_1), 
   io:fwrite("~n"), 
   io:fwrite('atom 1'), 
   io:fwrite("~n").

La sortie du programme ci-dessus serait la suivante -

Production

atom1

atom_1

atom 1

Voyons quelques-unes des méthodes disponibles dans Erlang pour travailler avec des atomes.

Sr.No. Méthodes et description
1

is_atom

Cette méthode est utilisée pour déterminer si un terme est bien un atome.

2

atom_to_list

Cette méthode est utilisée pour convertir un atome en liste.

3

list_to_atom

Cette méthode est utilisée pour convertir un élément de liste en atome.

4

atom_to_binary

Cette méthode est utilisée pour convertir un atome en une valeur binaire.

5

binary_to_atom

Cette méthode est utilisée pour convertir une valeur binaire en valeur d'atome.

Une carte est un type de données composé avec un nombre variable d'associations clé-valeur. Chaque association clé-valeur de la carte est appelée une paire d'associations. Les parties clé et valeur de la paire sont appelées éléments. On dit que le nombre de paires d'associations est la taille de la carte.

Un exemple de la façon dont le type de données Carte peut être utilisé est présenté dans le programme suivant.

Ici, nous définissons une carte M1 qui a 2 mappages. lemap_size est une fonction intégrée définie dans Erlang qui peut être utilisée pour déterminer la taille de la carte.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   M1 = #{name=>john,age=>25}, 
   io:fwrite("~w",[map_size(M1)]).

La sortie du programme ci-dessus sera la suivante.

Production

2

Certaines des autres méthodes disponibles pour les cartes sont les suivantes.

Sr.No. Méthodes et description
1

from_list

Cette méthode est utilisée pour générer une carte à partir d'une liste.

2

trouver

Cette méthode est utilisée pour trouver si une clé particulière existe dans la carte.

3

avoir

Cette méthode est utilisée pour obtenir la valeur d'une clé particulière dans la carte.

4

C est la clé

Cette méthode est utilisée pour déterminer si une clé particulière est définie comme clé dans la carte.

5

clés

Cette méthode est utilisée pour renvoyer toutes les clés d'une carte.

6

fusionner

Cette méthode est utilisée pour fusionner 2 cartes.

sept

mettre

Cette méthode est utilisée pour ajouter une paire clé / valeur à la carte.

8

valeurs

Cette méthode est utilisée pour renvoyer toutes les valeurs d'une carte.

9

retirer

Cette méthode est utilisée pour supprimer une valeur de clé de la carte.

Un tuple est un type de données composé avec un nombre fixe de termes. Chaque terme du Tuple est appelé un élément. On dit que le nombre d'éléments est la taille du Tuple.

Un exemple de la façon dont le type de données Tuple peut être utilisé est illustré dans le programme suivant.

Ici, nous définissons un Tuple Pqui a 3 termes. letuple_size est une fonction intégrée définie dans Erlang qui peut être utilisée pour déterminer la taille du Tuple.

Exemple

-module(helloworld). 
-export([start/0]). 

start() ->
   P = {john,24,{june,25}} , 
   io:fwrite("~w",[tuple_size(P)]).

La sortie du programme ci-dessus sera la suivante.

Production

3

Examinons quelques autres opérations disponibles pour les tuples.

Sr.No. Méthodes et description
1

is_tuple

Cette méthode est utilisée pour déterminer si le terme fourni est bien un tuple.

2

list_to_tuple

Cette méthode consiste à convertir une liste en un tuple.

3

tuple_to_list

Cette méthode consiste à convertir un tuple en liste.

Erlang a la possibilité supplémentaire de créer des enregistrements. Ces enregistrements se composent de champs. Par exemple, vous pouvez définir un enregistrement personnel qui a 2 champs, l'un est l'id et l'autre est le champ de nom. Dans Erlang, vous pouvez ensuite créer diverses instances de cet enregistrement pour définir plusieurs personnes avec différents noms et identifiants.

Explorons comment nous pouvons travailler avec les enregistrements.

Créer un enregistrement

Un enregistrement est créé à l'aide de l'identificateur d'enregistrement. Dans cet identifiant d'enregistrement, vous spécifiez les différents champs qui constituent l'enregistrement. La syntaxe générale et l'exemple sont donnés ci-dessous.

Syntaxe

record(recordname , {Field1,Field2 ..Fieldn})

Paramètres

  • recordname - C'est le nom donné au disque.

  • Field1,Field2 ..Fieldn - Ce sont la liste des différents champs qui constituent l'enregistrement.

Valeur de retour

Aucun

Par exemple

-module(helloworld). 
-export([start/0]). 
-record(person, {name = "", id}). 

start() -> 
   P = #person{name="John",id = 1}.

L'exemple ci-dessus montre la définition d'un enregistrement avec 2 champs, l'un est l'identifiant et l'autre le nom. En outre, un enregistrement est construit de la manière suivante -

Syntaxe

#recordname {fieldName1 = value1, fieldName2 = value2 .. fieldNameN = valueN}

Où vous affectez des valeurs aux champs respectifs lorsqu'une instance de l'enregistrement est définie.

Accéder à une valeur de l'enregistrement

Pour accéder aux champs et aux valeurs d'un enregistrement particulier, la syntaxe suivante doit être utilisée.

Syntaxe

#recordname.Fieldname

Paramètres

  • recordname - C'est le nom donné au disque.

  • Fieldname - C'est le nom du champ auquel il faut accéder.

Valeur de retour

La valeur attribuée au champ.

Par exemple

-module(helloworld). 
-export([start/0]). 
-record(person, {name = "", id}). 

start() -> 
   P = #person{name = "John",id = 1}, 
   io:fwrite("~p~n",[P#person.id]), 
   io:fwrite("~p~n",[P#person.name]).

Production

La sortie du programme ci-dessus est la suivante.

1
“John”

Mise à jour d'une valeur de l'enregistrement

La mise à jour d'une valeur d'enregistrement est effectuée en modifiant la valeur dans un champ particulier, puis en affectant l'enregistrement à un nouveau nom de variable. La syntaxe générale et l'exemple sont donnés ci-dessous.

Syntaxe

#recordname.Fieldname = newvalue

Paramètres

  • recordname - C'est le nom donné au disque.

  • Fieldname - C'est le nom du champ auquel il faut accéder.

  • newvalue - C'est la nouvelle valeur qui doit être affectée au champ.

Valeur de retour

Le nouvel enregistrement avec les nouvelles valeurs affectées aux champs.

Par exemple

-module(helloworld). 
-export([start/0]). 
-record(person, {name = "", id}). 

start() -> 
   P = #person{name = "John",id = 1}, 
   P1 = P#person{name = "Dan"}, 
   
   io:fwrite("~p~n",[P1#person.id]), 
   io:fwrite("~p~n",[P1#person.name]).

Production

La sortie du programme ci-dessus est la suivante -

1
“Dan”

Enregistrements imbriqués

Erlang a également la possibilité d'avoir des enregistrements imbriqués. L'exemple suivant montre comment ces enregistrements imbriqués peuvent être créés.

Par exemple

-module(helloworld). 
-export([start/0]). 
-record(person, {name = "", address}). 
-record(employee, {person, id}). 

start() -> 
   P = #employee{person = #person{name = "John",address = "A"},id = 1}, 
   io:fwrite("~p~n",[P#employee.id]).

Dans l'exemple ci-dessus, les choses suivantes doivent être notées -

  • Nous créons d'abord l'enregistrement d'une personne qui a les valeurs de champ de nom et d'adresse.

  • Nous définissons ensuite un enregistrement d'employé qui a la personne comme champ et un champ supplémentaire appelé id.

Production

La sortie du programme ci-dessus est la suivante.

1

La gestion des exceptions est requise dans tout langage de programmation pour gérer les erreurs d'exécution afin que le flux normal de l'application puisse être maintenu. L'exception perturbe normalement le flux normal de l'application, raison pour laquelle nous devons utiliser la gestion des exceptions dans notre application.

Normalement, lorsqu'une exception ou une erreur se produit à Erlang, le message suivant s'affiche.

{"init terminating in do_boot", {undef,[{helloworld,start,[],[]}, 
{init,start_it,1,[]},{init,start_em,1,[]}]}}

Le vidage sur incident sera écrit dans -

erl_crash.dump
init terminating in do_boot ()

À Erlang, il existe 3 types d'exceptions -

  • Error - Appel erlang:error(Reason)mettra fin à l'exécution dans le processus en cours et inclura une trace de pile des dernières fonctions appelées avec leurs arguments lorsque vous l'attraperez. Ce sont les types d'exceptions qui provoquent les erreurs d'exécution ci-dessus.

  • Exists- Il existe deux types de sorties: les sorties «internes» et les sorties «externes». Les sorties internes sont déclenchées en appelant la fonctionexit/1et faire en sorte que le processus en cours arrête son exécution. Les sorties externes sont appelées avecexit/2 et ont à voir avec de multiples processus dans l'aspect simultané d'Erlang.

  • Throw- Un throw est une classe d'exception utilisée pour les cas que le programmeur peut s'attendre à gérer. En comparaison avec les sorties et les erreurs, ils ne comportent pas vraiment de "crash ce processus!" l'intention derrière eux, mais plutôt ils contrôlent le flux. Lorsque vous utilisez les lancers en vous attendant à ce que le programmeur les gère, il est généralement judicieux de documenter leur utilisation dans un module qui les utilise.

UNE try ... catch est un moyen d'évaluer une expression tout en vous permettant de gérer le cas réussi ainsi que les erreurs rencontrées.

La syntaxe générale d'une expression try catch est la suivante.

Syntaxe

try Expression of 
SuccessfulPattern1 [Guards] -> 
Expression1; 
SuccessfulPattern2 [Guards] -> 
Expression2 

catch 
TypeOfError:ExceptionPattern1 -> 
Expression3; 
TypeOfError:ExceptionPattern2 -> 
Expression4 
end

L'expression entre les deux try and ofest dit protégé. Cela signifie que tout type d'exception se produisant dans cet appel sera intercepté. Les modèles et expressions entre lestry ... of and catch se comportent exactement de la même manière qu'un case ... of.

Enfin, la partie catch - ici, vous pouvez remplacer TypeOfErrorpar erreur, lancer ou quitter, pour chaque type respectif que nous avons vu dans ce chapitre. Si aucun type n'est fourni, un jet est supposé.

Voici quelques-unes des erreurs et les raisons d'erreur dans Erlang -

Erreur Type d'erreur
Badarg Mauvais argument. L'argument est d'un type de données incorrect ou est mal formé.
Badarith Mauvais argument dans une expression arithmétique.
{badmatch, V} L'évaluation d'une expression de correspondance a échoué. La valeur V ne correspond pas.
clause_fonction Aucune clause de fonction correspondante n'est trouvée lors de l'évaluation d'un appel de fonction.
{case_clause, V} Aucune branche correspondante n'est trouvée lors de l'évaluation d'une expression de cas. La valeur V ne correspond pas.
if_clause Aucune vraie branche n'est trouvée lors de l'évaluation d'une expression if.
{try_clause, V} Aucune branche correspondante n'est trouvée lors de l'évaluation de la section of d'une expression try. La valeur V ne correspond pas.
undef La fonction est introuvable lors de l'évaluation d'un appel de fonction.
{badfun, F} Quelque chose ne va pas avec un F amusant
{badarity, F} Un plaisir est appliqué au mauvais nombre d'arguments. F décrit le plaisir et les arguments.
timeout_value La valeur du délai d'expiration dans une expression receive..after est évaluée à autre chose qu'un entier ou l'infini.
noproc Essayer de se lier à un processus inexistant.

Voici un exemple de la façon dont ces exceptions peuvent être utilisées et comment les choses sont faites.

  • La première fonction génère tous les types d'exception possibles.

  • Ensuite, nous écrivons une fonction wrapper à appeler generate_exception dans une expression try ... catch.

Exemple

-module(helloworld). 
-compile(export_all). 

generate_exception(1) -> a; 
generate_exception(2) -> throw(a); 
generate_exception(3) -> exit(a); 
generate_exception(4) -> {'EXIT', a}; 
generate_exception(5) -> erlang:error(a). 

demo1() -> 
   [catcher(I) || I <- [1,2,3,4,5]]. 
catcher(N) -> 
   try generate_exception(N) of 
      Val -> {N, normal, Val} 
   catch 
      throw:X -> {N, caught, thrown, X}; 
      exit:X -> {N, caught, exited, X}; 
      error:X -> {N, caught, error, X} 
   end. 
      
demo2() -> 
   [{I, (catch generate_exception(I))} || I <- [1,2,3,4,5]]. 
demo3() -> 
   try generate_exception(5) 
   catch 
      error:X -> 
         {X, erlang:get_stacktrace()} 
   end. 
   
lookup(N) -> 
   case(N) of 
      1 -> {'EXIT', a}; 
      2 -> exit(a) 
   end.

Si nous exécutons le programme en tant que helloworld: demo (). , nous obtiendrons la sortie suivante -

Production

[{1,normal,a},
{2,caught,thrown,a},
{3,caught,exited,a},
{4,normal,{'EXIT',a}},
{5,caught,error,a}]

Les macros sont généralement utilisées pour les remplacements de code en ligne. Dans Erlang, les macros sont définies via les instructions suivantes.

  • -define (constante, remplacement).
  • -define (Func (Var1, Var2, .., Var), Replacement).

Voici un exemple de macros utilisant la première syntaxe -

Exemple

-module(helloworld). 
-export([start/0]). 
-define(a,1). 

start() -> 
   io:fwrite("~w",[?a]).

À partir du programme ci-dessus, vous pouvez voir que la macro est développée en utilisant le '?' symbole. La constante est remplacée en place par la valeur définie dans la macro.

La sortie du programme ci-dessus sera -

Production

1

Voici un exemple de macro utilisant la classe de fonctions:

Exemple

-module(helloworld). 
-export([start/0]). 
-define(macro1(X,Y),{X+Y}). 

start() ->
   io:fwrite("~w",[?macro1(1,2)]).

La sortie du programme ci-dessus sera -

Production

{3}

Les instructions supplémentaires suivantes sont disponibles pour les macros -

  • undef(Macro)- Annule la définition de la macro; après cela, vous ne pouvez pas appeler la macro.

  • ifdef(Macro) - Evalue les lignes suivantes uniquement si la macro a été définie.

  • ifndef(Macro) - Evalue les lignes suivantes uniquement si Macro n'est pas définie.

  • else- Autorisé après une instruction ifdef ou ifndef. Si la condition était fausse, les instructions suivantes else sont évaluées.

  • endif - Marque la fin d'une instruction ifdef ou ifndef.

Lorsque vous utilisez les instructions ci-dessus, il doit être utilisé de la manière appropriée, comme indiqué dans le programme suivant.

-ifdef(<FlagName>).

-define(...).
-else.
-define(...).
-endif.

Les fichiers d'en-tête sont comme des fichiers d'inclusion dans n'importe quel autre langage de programmation. Il est utile pour diviser les modules en différents fichiers, puis accéder à ces fichiers d'en-tête dans des programmes distincts. Pour voir les fichiers d'en-tête en action, regardons l'un de nos précédents exemples d'enregistrements.

Créons d'abord un fichier appelé user.hrl et ajoutez le code suivant -

-record(person, {name = "", id}).

Maintenant, dans notre fichier de programme principal, ajoutons le code suivant -

Exemple

-module(helloworld). 
-export([start/0]). 
-include("user.hrl"). 

start() -> 
   P = #person{name = "John",id = 1}, 
   io:fwrite("~p~n",[P#person.id]), 
   io:fwrite("~p~n",[P#person.name]).

Comme vous pouvez le voir dans le programme ci-dessus, nous incluons simplement le fichier user.hrl qui insère automatiquement le –record code dedans.

Si vous exécutez le programme ci-dessus, vous obtiendrez la sortie suivante.

Production

1
“John”

Vous pouvez également faire la même chose avec les macros, vous pouvez définir la macro dans le fichier d'en-tête et la référencer dans le fichier principal. Voyons un exemple de ceci -

Créons d'abord un fichier appelé user.hrl et ajoutez le code suivant -

-define(macro1(X,Y),{X+Y}).

Maintenant, dans notre fichier de programme principal, ajoutons le code suivant -

Exemple

-module(helloworld). 
-export([start/0]). 
-include("user.hrl"). 

start() -> 
   io:fwrite("~w",[?macro1(1,2)]).

Si vous exécutez le programme ci-dessus, vous obtiendrez la sortie suivante -

Production

{3}

Avant qu'un module Erlang ne soit compilé, il est automatiquement traité par le préprocesseur Erlang. Le préprocesseur développe toutes les macros qui peuvent se trouver dans le fichier source et insère tous les fichiers d'inclusion nécessaires.

Normalement, vous n'aurez pas besoin de regarder la sortie du préprocesseur, mais dans des circonstances exceptionnelles (par exemple, lors du débogage d'une macro défectueuse), vous voudrez peut-être enregistrer la sortie du préprocesseur. Pour voir le résultat du prétraitement du modulesome_module.erl donnez la commande shell du système d'exploitation.

erlc -P some_module.erl

Par exemple, supposons que nous ayons le fichier de code suivant -

Exemple

-module(helloworld). 
-export([start/0]). 
-include("user.hrl"). 

start() -> 
   io:fwrite("~w",[?macro1(1,2)]).

Et si nous exécutons la commande suivante à partir de la ligne de commande -

erlc –P helloworld.erl

Un fichier appelé helloworld.Pserait généré. Si vous ouvrez ce fichier, vous trouverez le contenu suivant, ce que le préprocesseur compilerait.

-file("helloworld.erl", 1). -module(helloworld).

-export([start/0]).
-file("user.hrl", 1).
-file("helloworld.erl", 3).

start() ->
   io:fwrite("~w", [{1 + 2}]).

Les motifs ressemblent à des termes - ils peuvent être de simples littéraux comme des atomes et des nombres, des composés comme des tuples et des listes, ou un mélange des deux. Ils peuvent également contenir des variables, qui sont des chaînes alphanumériques commençant par une majuscule ou un trait de soulignement. Une "variable anonyme" spéciale, _ (le trait de soulignement) est utilisée lorsque vous ne vous souciez pas de la valeur à rechercher et que vous ne l'utiliserez pas.

Un motif correspond s'il a la même «forme» que le terme correspondant, et les atomes rencontrés sont les mêmes. Par exemple, les correspondances suivantes réussissent -

  • B = 1.
  • 2 = 2.
  • {ok, C} = {ok, 40}.
  • [H | T] = [1, 2, 3,4].

Notez que dans le quatrième exemple, le tube (|) signifie la tête et la queue de la liste comme décrit dans Termes. Notez également que le côté gauche doit correspondre au côté droit, ce qui est le cas normal pour les motifs.

Les exemples suivants de correspondance de modèles échoueront.

  • 1 = 2.
  • {ok, A} = {échec, "Je ne connais pas la question"}.
  • [H | T] = [].

Dans le cas de l'opérateur de correspondance de modèle, un échec génère une erreur et le processus s'arrête. La façon dont cela peut être piégé et géré est traitée dans Erreurs. Les modèles sont utilisés pour sélectionner la clause d'une fonction qui sera exécutée.

Les gardes sont des constructions que nous pouvons utiliser pour augmenter la puissance de la correspondance de modèles. En utilisant des gardes, nous pouvons effectuer des tests simples et des comparaisons sur les variables d'un modèle.

La syntaxe générale de l'instruction de garde est la suivante -

function(parameter) when condition ->

Où,

  • Function(parameter) - Il s'agit de la déclaration de fonction utilisée dans la condition de garde.

  • Parameter - Généralement, la condition de garde est basée sur le paramètre.

  • Condition - La condition qui doit être évaluée pour voir si la fonction doit être exécutée ou non.

  • L'instruction when doit être utilisée lorsqu'une condition de garde est spécifiée.

Regardons un exemple rapide de la façon dont les gardes peuvent être utilisés -

Exemple

-module(helloworld). 
-export([display/1,start/0]). 

display(N) when N > 10 ->   
   io:fwrite("greater then 10"); 
display(N) when N < 10 -> io:fwrite("Less 
   than 10"). 

start() -> 
   display(11).

Les choses suivantes doivent être notées à propos de l'exemple ci-dessus -

  • La fonction d'affichage est définie avec une protection. La première déclaration d'affichage a une garde quand le paramètre N est supérieur à 10. Ainsi, si le paramètre est supérieur à 10, cette fonction sera appelée.

  • La fonction d'affichage est à nouveau définie, mais cette fois avec une garde inférieure à 10. De cette manière, vous pouvez définir la même fonction plusieurs fois, chacune avec une condition de garde distincte.

La sortie du programme ci-dessus sera la suivante -

Production

greater than 10

Les conditions de garde peuvent également être utilisées pour if else et casedéclarations. Voyons comment nous pouvons effectuer les opérations de garde sur ces déclarations.

Gardes pour les déclarations 'si'

Les gardes peuvent également être utilisées pour les instructions if afin que la série d'instructions exécutées soit basée sur la condition de garde. Voyons comment nous pouvons y parvenir.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   N = 9, 
   if 
      N > 10 -> 
         io:fwrite("N is greater than 10"); 
      true -> 
         io:fwrite("N is less than 10") 
   end.

Les choses suivantes doivent être notées à propos de l'exemple ci-dessus -

  • La fonction de garde est utilisée avec l'instruction if. Si la fonction de garde est évaluée à vrai, alors l'instruction «N est supérieur à 10» s'affiche.

  • Si la fonction de garde est évaluée à faux, alors l'instruction «N est inférieur à 10» s'affiche.

La sortie du programme ci-dessus sera la suivante -

Production

N is less than 10

Gardes pour les déclarations de cas

Les gardes peuvent également être utilisées pour les instructions case afin que la série d'instructions exécutées soit basée sur la condition de garde. Voyons comment nous pouvons y parvenir.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   A = 9, 
   case A of {A} when A>10 -> 
      io:fwrite("The value of A is greater than 10"); _ -> 
      io:fwrite("The value of A is less than 10") 
   end.

Les choses suivantes doivent être notées à propos de l'exemple ci-dessus -

  • La fonction de garde est utilisée avec l'instruction case. Si la fonction de garde est évaluée à vrai, alors l'instruction «La valeur de A est supérieure à 10» s'affiche.

  • Si la fonction de garde évalue autre chose, l'instruction «La valeur de A est inférieure à 10» s'affiche.

La sortie du programme ci-dessus sera la suivante -

Production

The value of A is less than 10

Conditions de garde multiples

Plusieurs conditions de garde peuvent également être spécifiées pour une fonction. La syntaxe générale de l'instruction de garde avec plusieurs conditions de garde est donnée ci-dessous -

function(parameter) when condition1 , condition1 , .. conditionN ->

Où,

  • Function(parameter) - Il s'agit de la déclaration de fonction qui a utilisé la condition de garde.

  • Parameter - Généralement, la condition de garde est basée sur le paramètre.

  • condition1, condition1, .. conditionN - Ce sont les conditions de garde multiples qui sont appliquées aux fonctions.

  • L'instruction when doit être utilisée lorsqu'une condition de garde est spécifiée.

Regardons un exemple rapide de la façon dont plusieurs gardes peuvent être utilisés -

Exemple

-module(helloworld). 
-export([display/1,start/0]). 

display(N) when N > 10 , is_integer(N) -> 
   io:fwrite("greater then 10"); 
display(N) when N < 10 -> 
   io:fwrite("Less than 10"). 
   
start() -> 
   display(11).

Le point suivant doit être noté à propos de l'exemple ci-dessus -

  • Vous remarquerez que pour la première déclaration de fonction d'affichage, en plus de la condition pour N> 10, la condition pour is_integerest également spécifié. Donc seulement si la valeur de N est un entier et supérieur à 10, cette fonction sera exécutée.

La sortie du programme ci-dessus sera la suivante -

Production

Greater than 10

Les BIF sont des fonctions intégrées à Erlang. Ils effectuent généralement des tâches impossibles à programmer à Erlang. Par exemple, il est impossible de transformer une liste en tuple ou de trouver l'heure et la date actuelles. Pour effectuer une telle opération, nous appelons un BIF.

Prenons un exemple de la façon dont les BIF sont utilisés -

Exemple

-module(helloworld). 
-export([start/0]). 

start() ->   
   io:fwrite("~p~n",[tuple_to_list({1,2,3})]), 
   io:fwrite("~p~n",[time()]).

Les choses suivantes doivent être notées à propos de l'exemple ci-dessus -

  • Dans le premier exemple, nous utilisons le BIF appelé tuple_to_list pour convertir un tuple en liste.

  • Dans la deuxième fonction BIF, nous utilisons le time function pour afficher l'heure système.

La sortie du programme ci-dessus sera la suivante -

Production

[1,2,3]
{10,54,56}

Examinons certaines des fonctions BIF les plus disponibles dans Erlang.

Sr.No. Fonctions et description du BIF
1

Date

Cette méthode renvoie la date système actuelle.

2

byte_size

Cette méthode renvoie le nombre d'octets contenus dans une Bitstring.

3

élément

La méthode renvoie le Nième élément du tuple.

4

flotte

Cette méthode renvoie la valeur flottante d'un nombre particulier.

5

avoir

La méthode renvoie le dictionnaire de processus sous forme de liste.

6

mettre

Cette méthode est utilisée pour mettre un key,value paire dans le dictionnaire de processus.

sept

heure locale

La méthode est utilisée pour donner la date et l'heure locales dans le système.

8

Mémoire

Renvoie une liste contenant des informations sur la mémoire allouée dynamiquement par l'émulateur Erlang.

9

maintenant

Cette méthode renvoie le tuple {MegaSecs, Secs, MicroSecs} qui est le temps écoulé depuis 00:00 GMT, le 1er janvier 1970.

dix

les ports

Renvoie une liste de tous les ports sur le nœud local

11

processus

Renvoie une liste d'identificateurs de processus correspondant à tous les processus existant actuellement sur le nœud local.

12

universalité

Renvoie la date et l'heure actuelles selon le temps universel coordonné (UTC).

Utilisez une structure de données appelée binaire pour stocker de grandes quantités de données brutes. Les binaires stockent les données de manière beaucoup plus efficace en termes d'espace que dans les listes ou les tuples, et le système d'exécution est optimisé pour l'entrée et la sortie efficaces des binaires.

Les fichiers binaires sont écrits et imprimés sous forme de séquences d'entiers ou de chaînes, entre parenthèses double inférieur et supérieur.

Voici un exemple de binaires dans Erlang -

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   io:fwrite("~p~n",[<<5,10,20>>]), 
   io:fwrite("~p~n",[<<"hello">>]).

Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant.

Production

<<5,10,20>>
<<"hello">>

Regardons les fonctions Erlang qui sont disponibles pour travailler avec les binaires -

Sr.No. Méthodes et description
1

list_to_binary

Cette méthode est utilisée pour convertir une liste existante en une liste de binaires.

2

split_binary

Cette méthode est utilisée pour fractionner la liste binaire en fonction de la position d'index spécifiée.

3

term_to_binary

Cette méthode est utilisée pour convertir un terme en binaire.

4

is_binary

Cette méthode est utilisée pour vérifier si une chaîne de bits est bien une valeur binaire.

5

partie_binaire

Cette méthode est utilisée pour extraire une partie de la chaîne binaire

6

binary_to_float

Cette méthode est utilisée pour convertir une valeur binaire en valeur flottante.

sept

binary_to_integer

Cette méthode est utilisée pour convertir une valeur binaire en une valeur entière.

8

liste_binaire

Cette méthode est utilisée pour convertir une valeur binaire en liste.

9

binary_to_atom

Cette méthode est utilisée pour convertir une valeur binaire en atome.

Les funs sont utilisés pour définir des fonctions anonymes dans Erlang. La syntaxe générale d'une fonction anonyme est donnée ci-dessous -

Syntaxe

F = fun (Arg1, Arg2, ... ArgN) ->
   ...
End

  • F - Il s'agit du nom de variable attribué à la fonction anonyme.

  • Arg1, Arg2, ... ArgN - Ce sont les arguments qui sont passés à la fonction anonyme.

L'exemple suivant montre comment la fonction anonyme peut être utilisée.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   A = fun() -> io:fwrite("Hello") end, 
   A().

Les choses suivantes doivent être notées à propos du programme ci-dessus.

  • La fonction anonyme est affectée à la variable A.

  • La fonction anonyme via la variable A ().

Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant.

“Hello”

Un autre exemple de fonction anonyme est le suivant, mais c'est avec l'utilisation de paramètres.

-module(helloworld). 
-export([start/0]). 

start() -> 
   A = fun(X) -> 
      io:fwrite("~p~n",[X]) 
      end, 
   A(5).

Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant.

Production

5

Utilisation de variables

La fonction anonyme a la capacité d'accéder aux variables qui sont en dehors de la portée de la fonction anonyme. Regardons un exemple de ceci -

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   B = 6, 
   A = fun(X) -> 
      io:fwrite("~p~n",[X]), 
      io:fwrite("~p~n",[B]) 
      end, 
   A(5).

Les choses suivantes doivent être notées à propos du programme ci-dessus.

  • La variable B est en dehors de la portée de la fonction anonyme.

  • La fonction anonyme peut toujours accéder à la variable définie dans la portée globale.

Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant.

Production

5

6

Fonctions dans les fonctions

L'un des autres aspects les plus puissants des fonctions d'ordre supérieur est que vous pouvez définir une fonction dans une fonction. Voyons un exemple de la façon dont nous pouvons y parvenir.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   Adder = fun(X) -> fun(Y) -> io:fwrite("~p~n",[X + Y]) end end, 
   A = Adder(6), 
   A(10).

Les choses suivantes doivent être notées à propos du programme ci-dessus.

  • L'additionneur est une fonction d'ordre supérieur définie comme fun (X).

  • La fonction Adder fun (X) a une référence à une autre fonction fun (Y).

Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant.

Production

16

La granularité de la concurrence dans Erlang est un processus. Un processus est une activité / tâche qui s'exécute simultanément et est indépendante des autres processus. Ces processus dans Erlang sont différents des processus et des threads que la plupart des gens connaissent. Les processus Erlang sont légers, fonctionnent en isolation (mémoire) des autres processus et sont planifiés par la machine virtuelle (VM) d'Erlang. Le temps de création du processus est très faible, l'empreinte mémoire d'un processus qui vient d'être généré est très faible et une seule VM Erlang peut avoir des millions de processus en cours d'exécution.

Un processus est créé à l'aide de la méthode spawn. La syntaxe générale de la méthode est donnée ci-dessous.

Syntaxe

spawn(Module, Name, Args)

Paramètres

  • Module - Il s'agit d'une valeur atomique prédéfinie qui doit être? MODULE.

  • Name - C'est le nom de la fonction à appeler lorsque le processus est défini.

  • Args - Ce sont les arguments qui doivent être envoyés à la fonction.

Valeur de retour

Renvoie l'ID de processus du nouveau processus créé.

Par exemple

Un exemple de la méthode spawn est présenté dans le programme suivant.

-module(helloworld). 
-export([start/0, call/2]). 

call(Arg1, Arg2) -> 
   io:format("~p ~p~n", [Arg1, Arg2]). 
start() -> 
   Pid = spawn(?MODULE, call, ["hello", "process"]), 
   io:fwrite("~p",[Pid]).

Les choses suivantes doivent être notées à propos du programme ci-dessus.

  • Une fonction appelée call est définie et sera utilisée pour créer le processus.

  • La méthode spawn appelle la fonction d'appel avec les paramètres hello et process.

Production

Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant.

<0.29.0>"hello" "process"

Regardons maintenant les autres fonctions disponibles avec les processus.

Sr.No. Méthodes et description
1

is_pid

Cette méthode est utilisée pour déterminer si un identifiant de processus existe.

2

is_process_alive

Ceci est appelé comme is_process_alive (Pid). Un Pid doit faire référence à un processus au niveau du nœud local.

3

pid_to_list

Il convertit un identifiant de processus en liste.

4

inscrit

Renvoie une liste avec les noms de tous les processus enregistrés.

5

soi

L'un des BIF les plus couramment utilisés, renvoie le pid des processus appelants.

6

S'inscrire

Ceci est utilisé pour enregistrer un processus dans le système.

sept

où se trouve

Il est appelé whereis (Nom). Renvoie le pid du processus qui est enregistré avec le nom.

8

se désinscrire

Ceci est utilisé pour désenregistrer un processus dans le système.

Pour envoyer un e-mail avec Erlang, vous devez utiliser un package disponible sur githubpour le même. Le lien github est -https://github.com/Vagabond/gen_smtp

Ce lien contient un smtp utilityqui peut être utilisé pour envoyer des e-mails depuis une application Erlang. Suivez les étapes pour avoir la possibilité d'envoyer un e-mail depuis Erlang

Step 1 - Téléchargez le erl files du github site. Les fichiers doivent être téléchargés dans le répertoire où votrehelloworld.erl l'application réside.

Step 2 - Compilez tous les smtp related files indiqué dans la liste suivante en utilisant le erlc command. Les fichiers suivants doivent être compilés.

  • smtp_util
  • gen_smtp_client
  • gen_smtp_server
  • gen_smtp_server_session
  • binstr
  • gen_smtp_application
  • socket

Step 3 - Le code suivant peut être écrit pour envoyer un e-mail en utilisant smtp.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   gen_smtp_client:send({"[email protected]", ["[email protected]"], "Subject: testing"},
   
   [{relay, "smtp.gmail.com"}, {ssl, true}, {username, "[email protected]"}, 
      {password, "senderpassword"}]).

Les choses suivantes doivent être notées à propos du programme ci-dessus

  • La fonction smtp ci-dessus est utilisée avec le serveur smtp disponible sur google.

  • Puisque nous voulions envoyer à l'aide d'un smtp sécurisé, nous spécifions le paramètre ssl sur true.

  • Vous devez spécifier le relais comme smtp.gmail.com.

  • Vous devez mentionner un nom d'utilisateur et un mot de passe qui ont accès pour envoyer l'e-mail.

Une fois que vous avez configuré tous les paramètres ci-dessus et exécuté le programme, le destinataire recevra avec succès un e-mail.

Erlang a la capacité de se connecter aux bases de données traditionnelles telles que SQL Server et Oracle. Erlang a uninbuilt odbc library qui peut être utilisé pour travailler avec des bases de données.

Connexion à la base de données

Dans notre exemple, nous allons utiliser Microsoft SQL Server. Avant de vous connecter à une base de données Microsoft SQL Server, assurez-vous que les pointeurs suivants sont cochés.

  • Vous avez créé une base de données TESTDB.

  • Vous avez créé une table EMPLOYEE dans TESTDB.

  • Cette table contient les champs FIRST_NAME, LAST_NAME, AGE, SEX et INCOME.

  • L'ID utilisateur "testuser" et le mot de passe "test123" sont définis pour accéder à TESTDB.

  • Assurez-vous que vous avez créé un DSN ODBC appelé usersqlserver qui crée une connexion ODBC à la base de données

Établir une connexion

Pour établir une connexion à la base de données, l'exemple de code suivant peut être utilisé.

Example

-module(helloworld). 
-export([start/0]). 

start() ->
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver;UID = testuser;PWD = test123", []), 
   io:fwrite("~p",[Ref]).

La sortie du programme ci-dessus est la suivante -

Output

<0.33.0>

Les choses suivantes doivent être notées à propos du programme ci-dessus.

  • La méthode de démarrage de la bibliothèque odbc est utilisée pour indiquer le début de l'opération de base de données.

  • La méthode de connexion nécessite un DSN, un nom d'utilisateur et un mot de passe pour se connecter.

Créer une table de base de données

La prochaine étape après la connexion à la base de données est de créer les tables dans notre base de données. L'exemple suivant montre comment créer une table dans la base de données à l'aide d'Erlang.

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver; UID = testuser;PWD = test123, []), 
   odbc:sql_query(Ref, "CREATE TABLE EMPLOYEE (FIRSTNAME char varying(20), 
   LASTNAME char varying(20), AGE integer, SEX char(1), INCOME integer)")

Si vous vérifiez maintenant la base de données, vous verrez qu'une table appelée EMPLOYEE sera créé.

Insertion d'un enregistrement dans la base de données

Il est nécessaire lorsque vous souhaitez créer vos enregistrements dans une table de base de données.

L'exemple suivant insérera un enregistrement dans la table des employés. Si la table est correctement mise à jour, l'enregistrement et l'instruction renverront la valeur de l'enregistrement mis à jour et le nombre d'enregistrements mis à jour.

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver; UID = testuser;PWD = test123", []), 
   io:fwrite("~p",[odbc:sql_query(Ref, 
   "INSERT INTO EMPLOYEE VALUES('Mac', 'Mohan', 20, 'M', 2000)")]).

La sortie du programme ci-dessus sera -

Output

{updated,1}

Récupération des enregistrements de la base de données

Erlang a également la capacité de récupérer des enregistrements de la base de données. Cela se fait via lesql_query method.

Un exemple est montré dans le programme suivant -

Example

-module(helloworld). 
-export([start/0]). 

start() ->
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver; UID = testuser;PWD = test123", []), 
   io:fwrite("~p",[odbc:sql_query(Ref, "SELECT * FROM EMPLOYEE") ]).

La sortie du programme ci-dessus sera la suivante -

Output

{selected,["FIRSTNAME","LASTNAME","AGE","SEX","INCOME"],
[{"Mac","Mohan",20,"M",2000}]}

Ainsi, vous pouvez voir que la commande d'insertion dans la dernière section a fonctionné et que la commande de sélection a renvoyé les bonnes données.

Récupération des enregistrements à partir de la base de données en fonction des paramètres

Erlang a également la capacité d'extraire des enregistrements de la base de données en fonction de certains critères de filtrage.

Un exemple est le suivant -

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN=usersqlserver; UID=testuser;PWD=test123", []), 
   io:fwrite("~p",[ odbc:param_query(Ref, "SELECT * FROM EMPLOYEE WHERE SEX=?", 
   [{{sql_char, 1}, ["M"]}])]).

La sortie du programme ci-dessus sera -

Output

{selected,["FIRSTNAME","LASTNAME","AGE","SEX","INCOME"],
         [{"Mac","Mohan",20,"M",2000}]}

Mise à jour des enregistrements à partir de la base de données

Erlang a également la capacité de mettre à jour les enregistrements de la base de données.

Un exemple pour le même est le suivant -

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver; UID = testuser;PWD = test123", []), 
   
   io:fwrite("~p",[ odbc:sql_query(Ref, "
      UPDATE EMPLOYEE SET AGE = 5 WHERE INCOME= 2000")]).

La sortie du programme ci-dessus sera -

Output

{updated,1}

Suppression d'enregistrements de la base de données

Erlang a également la capacité de supprimer des enregistrements de la base de données.

Un exemple pour le même est le suivant -

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver; UID = testuser;PWD = test123", []), 
   io:fwrite("~p",[ odbc:sql_query(Ref, "DELETE EMPLOYEE WHERE INCOME= 2000")]).

La sortie du programme ci-dessus sera la suivante -

Output

{updated,1}

Structure de la table

Erlang a également la capacité de décrire une structure de table.

Un exemple est le suivant -

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver; UID = testuser;PWD = test123", []), 
   io:fwrite("~p",[odbc:describe_table(Ref, "EMPLOYEE")]).

La sortie du programme ci-dessus sera la suivante -

Output

{ok,[{"FIRSTNAME",{sql_varchar,20}},
   {"LASTNAME",{sql_varchar,20}},
   {"AGE",sql_integer},
   {"SEX",{sql_char,1}},
   {"INCOME",sql_integer}]}

Nombre d'enregistrements

Erlang a également la capacité de récupérer le nombre total d'enregistrements dans une table.

Un exemple pour la même chose est montré dans le programme suivant.

Example

-module(helloworld). 
-export([start/0]). 

start() ->
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver; UID = sa;PWD = demo123", []), 
   io:fwrite("~p",[odbc:select_count(Ref, "SELECT * FROM EMPLOYEE")]).

La sortie du programme ci-dessus sera -

{ok,1}

Dans Erlang, les ports sont utilisés pour la communication entre différents programmes. Un socket est un point de terminaison de communication qui permet aux machines de communiquer sur Internet en utilisant le protocole Internet (IP).

Types de protocoles utilisés dans les ports

Il existe 2 types de protocoles disponibles pour la communication. L'un est UDP et l'autre est TCP. UDP permet aux applications de s'envoyer des messages courts (appelés datagrammes), mais il n'y a aucune garantie de livraison pour ces messages. Ils peuvent également arriver dans le désordre. TCP, en revanche, fournit un flux fiable d'octets qui sont livrés dans l'ordre tant que la connexion est établie.

Regardons un exemple simple d'ouverture d'un port en utilisant UDP.

Exemple

-module(helloworld). 
-export([start/0]). 

start() -> 
   {ok, Socket} = gen_udp:open(8789), 
   io:fwrite("~p",[Socket]).

Les choses suivantes doivent être notées à propos du programme ci-dessus

  • le gen_udp contient les modules d'Erlang utilisés pour la communication UDP.

  • Ici 8789 est le numéro de port qui est ouvert à Erlang. Vous devez vous assurer que ce numéro de port est disponible et peut être utilisé.

La sortie du programme ci-dessus est -

#Port<0.376>

Envoi d'un message sur le port

Une fois le port ouvert, un message peut être envoyé sur le port. Cela se fait via la méthode d'envoi. Regardons la syntaxe et l'exemple suivant.

Syntaxe

send(Socket, Address, Port, Packet)

Paramètres

  • Socket - Il s'agit du socket créé avec la commande gen_udp: open.

  • Address - Il s'agit de l'adresse de la machine à laquelle le message doit être envoyé.

  • port - Il s'agit du numéro de port sur lequel le message doit être envoyé.

  • Packet - Ce sont les détails du paquet ou du message qui doivent être envoyés.

Valeurs de retour

Un message ok est renvoyé si le message a été envoyé correctement.

Par exemple

-module(helloworld). 
-export([start/0]). 

start() ->
   {ok, Socket} = gen_udp:open(8789), 
   io:fwrite("~p",[Socket]), 
   io:fwrite("~p",[gen_udp:send 
   (Socket,"localhost",8789,"Hello")]).

Production

La sortie du programme ci-dessus sera la suivante.

#Port<0.376>ok

Recevoir un message sur le port

Une fois le port ouvert, un message peut également être reçu sur le port. Cela se fait via lerecv method. Regardons la syntaxe et l'exemple suivant.

Syntaxe

recv(Socket, length)

Paramètres

  • Socket - Il s'agit du socket créé avec la commande gen_udp: open.

  • Length - C'est la longueur du message qui doit être reçu.

Valeurs de retour

Un message ok est renvoyé si le message a été envoyé correctement.

Par exemple

-module(helloworld). 
-export([start/0]). 

start() ->
   {ok, Socket} = gen_udp:open(8789), 
   io:fwrite("~p",[Socket]), 
   io:fwrite("~p",[gen_udp:send(Socket,"localhost",8789,"Hello")]),
   io:fwrite("~p",[gen_udp:recv(Socket, 20)]).

Le programme complet

Maintenant, évidemment, nous ne pouvons pas avoir le même message d'envoi et de réception dans le même programme. Vous devez les faire définir dans différents programmes. Alors, créons le code suivant qui crée un composant serveur qui écoute les messages et un composant client qui envoie des messages.

Exemple

-module(helloworld). 
-export([start/0,client/1]). 

start() -> 
   spawn(fun() -> server(4000) end).

server(Port) ->
   {ok, Socket} = gen_udp:open(Port, [binary, {active, false}]), 
   io:format("server opened socket:~p~n",[Socket]), 
   loop(Socket). 

loop(Socket) ->
   inet:setopts(Socket, [{active, once}]), 
   receive 
      {udp, Socket, Host, Port, Bin} -> 
      io:format("server received:~p~n",[Bin]), 
      gen_udp:send(Socket, Host, Port, Bin), 
      loop(Socket) 
   end. 

client(N) -> 
   {ok, Socket} = gen_udp:open(0, [binary]), 
   io:format("client opened socket=~p~n",[Socket]), 
   ok = gen_udp:send(Socket, "localhost", 4000, N), Value = receive 
      {udp, Socket, _, _, Bin} ->
         io:format("client received:~p~n",[Bin]) after 2000 ->
      0 
   end, 
   
gen_udp:close(Socket), 
Value.

Les choses suivantes doivent être notées à propos du programme ci-dessus.

  • Nous définissons 2 fonctions, la première est serveur. Celui-ci servira à écouter sur le port 4000. Le second est le client qui servira à envoyer le message «Hello» au composant serveur.

  • La boucle de réception est utilisée pour lire les messages envoyés dans une boucle de définition.

Production

Vous devez maintenant exécuter le programme à partir de 2 fenêtres. La première fenêtre sera utilisée pour exécuter le composant serveur en exécutant le code suivant dans leerl command line window.

helloworld:start().

Cela affichera la sortie suivante dans la fenêtre de ligne de commande.

server opened socket:#Port<0.2314>

Maintenant, dans la deuxième fenêtre de ligne de commande erl, exécutez la commande suivante.

Helloworld:client(“<<Hello>>”).

Lorsque vous exécutez cette commande, la sortie suivante sera affichée dans la première fenêtre de ligne de commande.

server received:<<"Hello">>

Les programmes distribués sont les programmes conçus pour s'exécuter sur des réseaux d'ordinateurs et qui peuvent coordonner leurs activités uniquement par la transmission de messages.

Il existe un certain nombre de raisons pour lesquelles nous pourrions vouloir écrire des applications distribuées. En voici quelques uns.

  • Performance - Nous pouvons accélérer nos programmes en faisant en sorte que différentes parties du programme soient exécutées en parallèle sur différentes machines.

  • Reliability- Nous pouvons créer des systèmes tolérants aux pannes en structurant le système pour qu'il fonctionne sur plusieurs machines. Si une machine tombe en panne, nous pouvons continuer sur une autre machine.

  • Scalability- Au fur et à mesure que nous développons une application, nous épuiserons tôt ou tard les capacités de la machine la plus puissante. À ce stade, nous devons ajouter plus de machines pour augmenter la capacité. L'ajout d'une nouvelle machine doit être une opération simple qui ne nécessite pas de modifications importantes de l'architecture de l'application.

Le concept central dans l'Erlang distribué est le nœud. Un nœud est un élément autonome.

Le système Erlang contient une machine virtuelle complète avec son propre espace d'adressage et son propre ensemble de processus.

Regardons les différents methods qui sont utilisés pour Distributed Programming.

Sr.No. Méthodes et description
1

frayer

Ceci est utilisé pour créer un nouveau processus et l'initialiser.

2

nœud

Ceci est utilisé pour déterminer la valeur du nœud sur lequel le processus doit s'exécuter.

3

spawn sur Node

Ceci est utilisé pour créer un nouveau processus sur un nœud.

4

est vivant

Cela renvoie vrai si le nœud local est actif et peut faire partie d'un système distribué.

5

spawnlink

Ceci est utilisé pour créer un nouveau lien de processus sur un nœud.

OTP signifie Open Telecom Platform. Il s'agit d'un système d'exploitation d'application et d'un ensemble de bibliothèques et de procédures utilisées pour créer des applications distribuées à grande échelle, tolérantes aux pannes. Si vous souhaitez programmer vos propres applications en utilisant OTP, le concept central que vous trouverez très utile est le comportement OTP. Un comportement encapsule des modèles de comportement courants - pensez-y comme un cadre d'application qui est paramétré par un module de rappel.

La puissance d'OTP provient des propriétés telles que la tolérance aux pannes, l'évolutivité, la mise à niveau du code dynamique, etc., peuvent être fournies par le comportement lui-même. Donc, le premier concept de base est de créer un composant serveur qui imite les bases d'un environnement OTP, regardons l'exemple suivant pour le même.

Exemple

-module(server). 
-export([start/2, rpc/2]). 

start(Name, Mod) -> 
   register(Name, spawn(fun() -> loop(Name, Mod, Mod:init()) end)). 
rpc(Name, Request) -> 
   Name ! {self(), Request}, 
   receive 
      {Name, Response} -> Response 
   end. 
   
loop(Name, Mod, State) ->
   receive 
      {From, Request} ->
         {Response, State1} = Mod:handle(Request, State), 
         From ! {Name, Response}, 
         loop(Name, Mod, State1) 
   end.

Les choses suivantes doivent être notées à propos du programme ci-dessus -

  • Le processus s'il est enregistré avec le système à l'aide de la fonction d'enregistrement.

  • Le processus génère une fonction de boucle qui gère le traitement.

Écrivons maintenant un programme client qui utilisera le programme serveur.

Exemple

-module(name_server). 
-export([init/0, add/2, whereis/1, handle/2]). 
-import(server1, [rpc/2]). 

add(Name, Place) -> rpc(name_server, {add, Name, Place}). 
whereis(Name) -> rpc(name_server, {whereis, Name}). 

init() -> dict:new().
handle({add, Name, Place}, Dict) -> {ok, dict:store(Name, Place, Dict)}; 
handle({whereis, Name}, Dict) -> {dict:find(Name, Dict), Dict}.

Ce code effectue en fait deux tâches. Il sert de module de rappel qui est appelé à partir du code de structure du serveur, et en même temps, il contient les routines d'interfaçage qui seront appelées par le client. La convention OTP habituelle est de combiner les deux fonctions dans le même module.

Alors, voici comment le programme ci-dessus doit être exécuté -

Dans erl, exécutez d'abord le programme serveur en exécutant la commande suivante.

server(name_server,name_server)

Vous obtiendrez la sortie suivante -

Production

true

Ensuite, exécutez la commande suivante

name_server.add(erlang,”Tutorialspoint”).

Vous obtiendrez la sortie suivante -

Production

Ok

Ensuite, exécutez la commande suivante -

name_server.whereis(erlang).

Vous obtiendrez la sortie suivante -

Production

{ok,"Tutorialspoint"}

La programmation simultanée dans Erlang doit avoir les principes ou processus de base suivants.

La liste comprend les principes suivants -

piD = spawn (amusant)

Crée un nouveau processus simultané qui évalue Fun. Le nouveau processus s'exécute en parallèle avec l'appelant. Un exemple est le suivant -

Exemple

-module(helloworld). 
-export([start/0]). 

start() ->
   spawn(fun() -> server("Hello") end). 

server(Message) ->
   io:fwrite("~p",[Message]).

La sortie du programme ci-dessus est -

Production

“Hello”

Pid! Message

Envoie un message au processus avec l'identifiant Pid. L'envoi de message est asynchrone. L'expéditeur n'attend pas mais continue ce qu'il faisait.‘!’ est appelé l'opérateur d'envoi.

Un exemple est le suivant -

Exemple

-module(helloworld). 
-export([start/0]). 
start() -> 
   Pid = spawn(fun() -> server("Hello") end), 
   Pid ! {hello}. 

server(Message) ->
   io:fwrite("~p",[Message]).

Recevoir… fin

Reçoit un message qui a été envoyé à un processus. Il a la syntaxe suivante -

Syntaxe

receive

Pattern1 [when Guard1] ->

Expressions1;

Pattern2 [when Guard2] ->

Expressions2;
...
End

Lorsqu'un message arrive au processus, le système essaie de le comparer à Pattern1 (avec une possible garde Guard1); si cela réussit, il évalue Expressions1. Si le premier modèle ne correspond pas, il essaie Pattern2, et ainsi de suite. Si aucun des modèles ne correspond, le message est enregistré pour un traitement ultérieur et le processus attend le message suivant.

Un exemple de l'ensemble du processus avec les 3 commandes est présenté dans le programme suivant.

Exemple

-module(helloworld). 
-export([loop/0,start/0]). 

loop() ->
   receive 
      {rectangle, Width, Ht} -> 
         io:fwrite("Area of rectangle is ~p~n" ,[Width * Ht]), 
         loop(); 
      {circle, R} ->
      io:fwrite("Area of circle is ~p~n" , [3.14159 * R * R]), 
      loop(); 
   Other ->
      io:fwrite("Unknown"), 
      loop() 
   end. 

start() ->
   Pid = spawn(fun() -> loop() end), 
   Pid ! {rectangle, 6, 10}.

Les choses suivantes doivent être notées à propos du programme ci-dessus -

  • La fonction de boucle a la boucle de fin de réception. Ainsi, lorsqu'un message est envoyé, il sera traité par la boucle de fin de réception.

  • Un nouveau processus est généré qui va à la fonction de boucle.

  • Le message est envoyé au processus généré via le Pid! commande de message.

La sortie du programme ci-dessus est -

Production

Area of the Rectangle is 60

Nombre maximum de processus

Dans la concurrence, il est important de déterminer le nombre maximum de processus autorisés sur un système. Vous devriez alors être en mesure de comprendre combien de processus peuvent s'exécuter simultanément sur un système.

Voyons un exemple de la façon dont nous pouvons déterminer quel est le nombre maximum de processus pouvant s'exécuter sur un système.

-module(helloworld). 
-export([max/1,start/0]). 

max(N) -> 
   Max = erlang:system_info(process_limit), 
   io:format("Maximum allowed processes:~p~n" ,[Max]), 
   
   statistics(runtime), 
   statistics(wall_clock), 
   
   L = for(1, N, fun() -> spawn(fun() -> wait() end) end), 
   {_, Time1} = statistics(runtime), 
   {_, Time2} = statistics(wall_clock), lists:foreach(fun(Pid) -> Pid ! die end, L), 
   
   U1 = Time1 * 1000 / N, 
   U2 = Time2 * 1000 / N, 
   io:format("Process spawn time=~p (~p) microseconds~n" , [U1, U2]).
   wait() -> 
   
   receive 
      die -> void 
   end. 
 
for(N, N, F) -> [F()]; 
for(I, N, F) -> [F()|for(I+1, N, F)]. 

start()->
   max(1000), 
   max(100000).

Sur n'importe quelle machine qui a une bonne puissance de traitement, les deux fonctions max ci-dessus passeront. Voici un exemple de sortie du programme ci-dessus.

Maximum allowed processes:262144

Process spawn time=47.0 (16.0) microseconds

Maximum allowed processes:262144

Process spawn time=12.81 (10.15) microseconds

Recevoir avec un timeout

Parfois, une instruction de réception peut attendre indéfiniment un message qui ne vient jamais. Cela peut être dû à plusieurs raisons. Par exemple, il peut y avoir une erreur logique dans notre programme, ou le processus qui allait nous envoyer un message peut s'être bloqué avant d'envoyer le message. Pour éviter ce problème, nous pouvons ajouter un délai d'expiration à l'instruction de réception. Cela définit une durée maximale pendant laquelle le processus attendra pour recevoir un message.

Voici la syntaxe du message de réception avec un délai spécifié

Syntaxe

receive 
Pattern1 [when Guard1] -> 
Expressions1; 

Pattern2 [when Guard2] ->
Expressions2; 
... 
after Time -> 
Expressions 
end

L'exemple le plus simple consiste à créer une fonction sleeper comme indiqué dans le programme suivant.

Exemple

-module(helloworld). 
-export([sleep/1,start/0]). 

sleep(T) ->
   receive 
   after T -> 
      true 
   end. 
   
start()->
   sleep(1000).

Le code ci-dessus dormira pendant 1000 ms avant de quitter réellement.

Réception sélective

Chaque processus d'Erlang a une boîte aux lettres associée. Lorsque vous envoyez un message au processus, le message est placé dans la boîte aux lettres. Le seul moment où cette boîte aux lettres est examinée est lorsque votre programme évalue une instruction de réception.

Voici la syntaxe générale de l'instruction de réception sélective.

Syntaxe

receive 
Pattern1 [when Guard1] ->
Expressions1; 

Pattern2 [when Guard1] ->
Expressions1; 
... 
after 
Time ->
ExpressionTimeout 
end

Voici comment fonctionne l'instruction de réception ci-dessus -

  • Lorsque nous entrons une instruction de réception, nous démarrons un minuteur (mais uniquement si une section après est présente dans l'expression).

  • Prenez le premier message dans la boîte aux lettres et essayez de le comparer à Pattern1, Pattern2, etc. Si la correspondance réussit, le message est supprimé de la boîte aux lettres et les expressions suivant le modèle sont évaluées.

  • Si aucun des modèles de l'instruction de réception ne correspond au premier message de la boîte aux lettres, le premier message est supprimé de la boîte aux lettres et placé dans une «file d'attente de sauvegarde». Le deuxième message de la boîte aux lettres est ensuite essayé. Cette procédure est répétée jusqu'à ce qu'un message correspondant soit trouvé ou jusqu'à ce que tous les messages de la boîte aux lettres aient été examinés.

  • Si aucun des messages de la boîte aux lettres ne correspond, le processus est suspendu et sera replanifié pour exécution la prochaine fois qu'un nouveau message est placé dans la boîte aux lettres. Notez que lorsqu'un nouveau message arrive, les messages de la file d'attente de sauvegarde ne sont pas remis en correspondance; seul le nouveau message correspond.

  • Dès qu'un message a été mis en correspondance, tous les messages qui ont été placés dans la file d'attente de sauvegarde sont réentrés dans la boîte aux lettres dans l'ordre dans lequel ils sont arrivés au processus. Si une minuterie a été réglée, elle est effacée.

  • Si le minuteur s'écoule lorsque nous attendons un message, évaluez les expressions ExpressionsTimeout et remettez tous les messages enregistrés dans la boîte aux lettres dans l'ordre dans lequel ils sont arrivés au processus.

Quand on parle de performance, les points suivants doivent être notés à propos d'Erlang.

  • Funs are very fast - Funs a reçu son propre type de données dans R6B et a été encore optimisé dans R7B.

  • Using the ++ operator- Cet opérateur doit être utilisé de manière appropriée. L'exemple suivant est la mauvaise façon d'effectuer une opération ++.

Exemple

-module(helloworld). 
-export([start/0]). 

start()->
   fun_reverse([H|T]) ->
   fun_reverse(T)++[H]; 
   fun_reverse([]) ->
   [].

Lorsque l'opérateur ++ copie son opérande gauche, le résultat est copié à plusieurs reprises, ce qui entraîne une complexité quadratique.

  • Using Strings- La gestion des chaînes peut être lente si elle n'est pas effectuée correctement. Dans Erlang, vous devez réfléchir un peu plus à la façon dont les chaînes sont utilisées et choisir une représentation appropriée. Si vous utilisez des expressions régulières, utilisez le re-module dans STDLIB au lieu duobsolete regexp module.

  • BEAM is a Stack-Based Byte-Code Virtual Machine- BEAM est une machine virtuelle basée sur des registres. Il a 1024 registres virtuels qui sont utilisés pour contenir des valeurs temporaires et pour passer des arguments lors de l'appel de fonctions. Les variables qui doivent survivre à un appel de fonction sont enregistrées dans la pile. BEAM est un interpréteur de code thread. Chaque instruction est un mot pointant directement vers un code C exécutable, ce qui rend la distribution des instructions très rapide.

Parfois, nous voulons exécuter un programme en langue étrangère dans le système d'exécution Erlang. Dans ce cas, le programme est écrit en tant que bibliothèque partagée qui est liée dynamiquement au système d'exécution Erlang. Le pilote lié apparaît au programmeur comme un programme de port et obéit exactement au même protocole que pour un programme de port.

Créer un pilote

La création d'un pilote lié est le moyen le plus efficace d'interfacer du code en langue étrangère avec Erlang, mais c'est aussi le plus dangereux. Toute erreur fatale dans le pilote lié fera planter le système Erlang.

Voici un exemple d'implémentation de pilote dans Erlang -

Exemple

-module(helloworld). 
-export([start/0, stop/0]). 
-export([twice/1, sum/2]). 

start() ->
   start("example1_drv" ). 
start(SharedLib) ->
   case erl_ddll:load_driver("." , SharedLib) of 
   ok -> ok; 
      {error, already_loaded} -> ok; 
      _ -> exit({error, could_not_load_driver}) 
   end, 
   
   spawn(fun() -> init(SharedLib) end). 

init(SharedLib) -> 
   register(example1_lid, self()), 
   Port = open_port({spawn, SharedLib}, []), 
   loop(Port). 

stop() -> 
   example1_lid ! stop. 

twice(X) -> call_port({twice, X}). 
sum(X,Y) -> call_port({sum, X, Y}). call_port(Msg) -> 
   example1_lid ! {call, self(), Msg}, receive 
      {example1_lid, Result} -> 
      Result 
   end. 

LINKED-IN DRIVERS 223 
loop(Port) -> 
receive 
   {call, Caller, Msg} -> 
   Port ! {self(), {command, encode(Msg)}}, receive 
   {Port, {data, Data}} ->
   Caller ! {example1_lid, decode(Data)} 
   end, 

loop(Port); 
stop -> Port ! 
   {self(), close}, 
   receive 
      {Port, closed} -> 
      exit(normal) 
   end; 
   
      {'EXIT', Port, Reason} -> 
      io:format("~p ~n" , [Reason]), 
      exit(port_terminated) 
   end. 

encode({twice, X}) -> [1, X]; 
encode({sum, X, Y}) -> [2, X, Y]. decode([Int]) -> Int.

Veuillez noter que travailler avec des pilotes est extrêmement complexe et que des précautions doivent être prises lorsque vous travaillez avec des pilotes.

À Erlang, le inets libraryest disponible pour créer des serveurs Web à Erlang. Examinons quelques-unes des fonctions disponibles dans Erlang pour la programmation Web. On peut implémenter le serveur HTTP, également appelé httpd pour gérer les requêtes HTTP.

Le serveur implémente de nombreuses fonctionnalités, telles que -

  • Secure Sockets Layer (SSL)
  • Interface de script Erlang (ESI)
  • Interface de passerelle commune (CGI)
  • Authentification de l'utilisateur (à l'aide de Mnesia, Dets ou base de données de texte brut)
  • Format de fichier journal commun (avec ou sans prise en charge de disk_log (3))
  • Alias ​​d'URL
  • Mappages d'action
  • Listes de l'annuaire

Le premier travail consiste à démarrer la bibliothèque Web via la commande.

inets:start()

L'étape suivante consiste à implémenter la fonction de démarrage de la bibliothèque inets afin que le serveur Web puisse être implémenté.

Voici un exemple de création d'un processus de serveur Web à Erlang.

Par exemple

-module(helloworld). 
-export([start/0]). 

start() ->
   inets:start(), 
   Pid = inets:start(httpd, [{port, 8081}, {server_name,"httpd_test"}, 
   {server_root,"D://tmp"},{document_root,"D://tmp/htdocs"},
   {bind_address, "localhost"}]), io:fwrite("~p",[Pid]).

Les points suivants doivent être notés à propos du programme ci-dessus.

  • Le numéro de port doit être unique et ne doit être utilisé par aucun autre programme. lehttpd service serait démarré sur ce port no.

  • le server_root et document_root sont des paramètres obligatoires.

Production

Voici la sortie du programme ci-dessus.

{ok,<0.42.0>}

Pour mettre en œuvre un Hello world web server à Erlang, effectuez les étapes suivantes -

Step 1 - Implémentez le code suivant -

-module(helloworld). 
-export([start/0,service/3]). 

start() ->
   inets:start(httpd, [ 
      {modules, [ 
         mod_alias, 
         mod_auth, 
         mod_esi, 
         mod_actions, 
         mod_cgi, 
         mod_dir,
         mod_get, 
         mod_head, 
         mod_log, 
         mod_disk_log 
      ]}, 
      
      {port,8081}, 
      {server_name,"helloworld"}, 
      {server_root,"D://tmp"}, 
      {document_root,"D://tmp/htdocs"}, 
      {erl_script_alias, {"/erl", [helloworld]}}, 
      {error_log, "error.log"}, 
      {security_log, "security.log"}, 
      {transfer_log, "transfer.log"}, 
      
      {mime_types,[ 
         {"html","text/html"}, {"css","text/css"}, {"js","application/x-javascript"} ]} 
   ]). 
         
service(SessionID, _Env, _Input) -> mod_esi:deliver(SessionID, [ 
   "Content-Type: text/html\r\n\r\n", "<html><body>Hello, World!</body></html>" ]).

Step 2- Exécutez le code comme suit. Compilez le fichier ci-dessus, puis exécutez les commandes suivantes danserl.

c(helloworld).

Vous obtiendrez la sortie suivante.

{ok,helloworld}

La commande suivante est -

inets:start().

Vous obtiendrez la sortie suivante.

ok

La commande suivante est -

helloworld:start().

Vous obtiendrez la sortie suivante.

{ok,<0.50.0>}

Step 3 - Vous pouvez maintenant accéder à l'url - http://localhost:8081/erl/hello_world:service.