Contactez-nous
Implantation
Langage CAML
H3018 v1 Archive

Implantation
Langage CAML

Auteur(s) : Guy COUSINEAU

Date de publication : 10 févr. 1998

Logo Techniques de l'Ingenieur Cet article est réservé aux abonnés
Pour explorer cet article plus en profondeur Consulter l'extrait gratuit

Déjà abonné ?

Présentation

1 - Principes

2 - Description du noyau

3 - Typage et modularité

  • 3.1 - Synthèse de types
  • 3.2 - Modules

4 - CAML et la programmation classique

  • 4.1 - CAML et les pointeurs
  • 4.2 - CAML et les objets
  • 4.3 - Interfaçage avec C

5 - CAML et l’analyse syntaxique

  • 5.1 - Flots
  • 5.2 - Filtrage de flots

6 - Implantation

7 - Comparaison avec d’autres langages fonctionnels

  • 7.1 - Autres langages de la famille ML
  • 7.2 - La famille LISP
  • 7.3 - Les langages fonctionnels « paresseux »

8 - Conclusion

Sommaire

Présentation

Auteur(s)

Lire cet article issu d'une ressource documentaire complète, actualisée et validée par des comités scientifiques.

Lire l’article

INTRODUCTION

Le langage CAML est développé en France par l’INRIA. Il fait partie d’une famille de langages baptisée ML dont un autre exemple est le langage SML développé aux États-Unis par les Bell labs. Plus généralement, il se rattache à la famille des langages fonctionnels dont font aussi partie LISP et SCHEME. Il se distingue toutefois assez nettement de ces langages par son typage et sa syntaxe.

Les principaux attraits de CAML sont la rapidité de développement et la sureté de la programmation. La richesse et la simplicité de ses structures de données ainsi que la puissance d’expression du modèle fonctionnel en font un outil bien adapté au développement rapide d’applications de nature symbolique. Par ailleurs, son système de types et de modules favorise la correction et réduit de façon importante les phases de mise au point.

CAML est issu du monde de la recherche et les principales applications qui ont été réalisées en CAML à ce jour sont des logiciels expérimentaux comme des démonstrateurs automatiques et autres outils d’aide à la vérification de logiciels. Il est très utilisé aussi pour l’enseignement de l’informatique dans les universités et a été choisi en 1995 pour la nouvelle option informatique des classes préparatoires.

En revanche, CAML n’a pas encore réussi de véritable percée dans le monde industriel où pourtant il pourrait apporter des gains de productivité importants. Cela vient peut-être de ce que les développeurs ont d’abord dû se concentrer sur les problèmes d’efficacité liés à l’allocation et à la récupération automatique de mémoire pour donner à CAML des performances équivalentes à celles des langages couramment utilisés comme C ou C++. Une fois ces problèmes résolus de façon satisfaisante, il est devenu clair que le principal problème résiduel était l’interfaçage de CAML, c’est-à-dire la facilité d’intégrer des modules développés en CAML à une chaîne classique de développement logiciel. De ce point de vue, CAML a maintenant atteint sa maturité et c’est aux équipes industrielles de déterminer quelle sera la place de ce type de langages dans les développements logiciels.

Quelle que soit à l’avenir la place du langage CAML lui-même, il semble, en tout cas, raisonnable de penser que les idées introduites par les langages de la famille ML sont suffisamment novatrices pour avoir une influence importante sur la conception des futurs langages de programmation.

Logo Techniques de l'Ingenieur

Cet article est réservé aux abonnés.
Il vous reste 94 % à découvrir.

Pour explorer cet article Consulter l'extrait gratuit

Déjà abonné ?


DOI (Digital Object Identifier)

https://doi.org/10.51257/a-v1-h3018

Article inclus dans l'offre

"Technologies logicielles Architectures des systèmes"

(237 articles)

Une base complète d’articles

Actualisée et enrichie d’articles validés par nos comités scientifiques.

Des contenus enrichis

Quiz, médias, tableaux, formules, vidéos, etc.

Des modules pratiques

Opérationnels et didactiques, pour garantir l'acquisition des compétences transverses.

Des avantages inclus

Un ensemble de services exclusifs en complément des ressources.

Voir l'offre

6. Implantation

Le langage CAML peut être utilisé à travers deux types de compilateurs. Le premier produit un bytecode qui est ensuite évalué. Le second produit du code natif pour différents processeurs. Le second est plus rapide que le premier d’un ordre de grandeur et permet d’atteindre des performances comparables à celles des compilateurs C sur des exemples comparables. Le premier est utilisé en particulier dans l’environnement interactif fourni avec le langage et c’est le seul qui soit fourni dans la version CAML LIGHT. Dans les deux types de compilateurs, l’implantation de la gestion mémoire est particulièrement efficace et pénalise peu l’exécution. On pourra consulter [4] pour une description des techniques utilisées.

Le modèle d’exécution choisi [7] repose sur la notion d’environnement et de fermeture pour la représentation des valeurs fonctionnelles. Ce modèle était déjà celui proposé par Landin pour la machine SECD, premier modèle d’exécution du lambda-calcul [6] et il avait fait l’objet d’une première implantation efficace par Cardelli [2].

Toutes les versions de CAML sont disponibles gratuitement et accessibles sur le site Web de l’INRIA.

HAUT DE PAGE
Logo Techniques de l'Ingenieur

Cet article est réservé aux abonnés.
Il vous reste 94 % à découvrir.

Pour explorer cet article Consulter l'extrait gratuit

Déjà abonné ?


Lecture en cours
Implantation

Article inclus dans l'offre

"Technologies logicielles Architectures des systèmes"

(237 articles)

Une base complète d’articles

Actualisée et enrichie d’articles validés par nos comités scientifiques.

Des contenus enrichis

Quiz, médias, tableaux, formules, vidéos, etc.

Des modules pratiques

Opérationnels et didactiques, pour garantir l'acquisition des compétences transverses.

Des avantages inclus

Un ensemble de services exclusifs en complément des ressources.

Voir l'offre

Sommaire
Sommaire

BIBLIOGRAPHIE

  • (1) - BARENDREGT (H.P.) -   The lambda-calculus : its syntax and semantics.  -  North Holland, 1987.

  • (2) - CARDELLI (L.) -   The functional abstract machine.  -  Rapport de recherche no 107, Bell labs, 1983.

  • (3) - COUSINEAU (G.), MAUNY (M.) -   Approche fonctionnelle de la programmation.  -  Édiscience, 1995.

  • (4) - DOLIGEZ (D.) -   Conception, réalisation et certification d’un glaneur de cellules concurrent.  -  Thèse de Doctorat, Université Paris VII, 1994.

  • (5) - HARDIN (T.), DONZEAU-GOUGE-VIGUIÉ (V.) -   Concepts et outils de programmation.  -  InterÉditions, 1992.

  • (6) - LANDIN (P.J.) -   The mechanical evaluation of expressions.  -  Computer Journal, vol. 6, 1964, pp. 308-320.

  • ...

DANS NOS BASES DOCUMENTAIRES

ANNEXES

  1. 1 Fournisseurs

    1 Fournisseurs

    L’ensemble des compilateurs et environnements de CAML est disponible sur le serveur général de l’INRIA : http://www.inria.fr

    HAUT DE PAGE
    Logo Techniques de l'Ingenieur

    Cet article est réservé aux abonnés.
    Il vous reste 95 % à découvrir.

    Pour explorer cet article Consulter l'extrait gratuit

    Déjà abonné ?


    Article inclus dans l'offre

    "Technologies logicielles Architectures des systèmes"

    (237 articles)

    Une base complète d’articles

    Actualisée et enrichie d’articles validés par nos comités scientifiques.

    Des contenus enrichis

    Quiz, médias, tableaux, formules, vidéos, etc.

    Des modules pratiques

    Opérationnels et didactiques, pour garantir l'acquisition des compétences transverses.

    Des avantages inclus

    Un ensemble de services exclusifs en complément des ressources.

    Voir l'offre