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
Où
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.