Accueil🇫🇷Chercher

Simula

Simula (Simple universal language) a été créé en 1962 sous la dénomination Simula I par Ole-Johan Dahl et Kristen Nygaard à partir d'Algol 60. Le langage évolua en 1967 sous le nom de Simula 67 en implantant le premier le modèle de classe de Hoare (Record Class, Hoare 1965). Il est donc le premier langage à classes et donc le père de tous les langages à classes tels que Smalltalk, C++, Java, ou encore Eiffel. Il inspira Dan Ingalls dans la conception de Smalltalk qui introduisit la programmation orientée objet. C'est la raison pour laquelle Simula 67 est souvent considéré à tort comme le premier langage orienté objet alors que ce paradigme est introduit bien après Simula 67 dans les années 1970 par Alan Kay.

Simula
Logo.

Date de première version 1967
Paradigmes Objet
Auteur Ole-Johan Dahl, Kristen Nygaard
Dernière version Simula I ()
Simula 67 ()
Influencé par Algol 60
A influencé Les langages orientés objet

Historique

Simula a été développé dans les années 1960 au Norwegian Computing Centre d'Oslo, initialement par Ole-Johan Dahl et Kristen Nygaard. Syntaxiquement parlant, c'est un sur-ensemble d'Algol, qui ajoute à celui-ci les concepts, aujourd'hui familiers, des langages à classes comme C++ ou Java, et de la simulation à événements discrets.

Simula a été utilisé pour des applications industrielles jusqu'à aujourd'hui, mais son influence historique est considérée comme plus importante que les applications qui auraient pu être développées avec lui.

Par Simula on entend généralement Simula 67, c'est-à-dire la version de 1967, alors que la version précédente datait de 1962 : Simula I.

Simulation discrète

Comme son nom l'indique, en plus de constituer un langage de programmation généraliste, Simula a été conçu de façon à contenir des bibliothèques de classes offrant un support de concepts spécifiques à la simulation à événements discrets. La classe Process, héritant de Simulation permettait ainsi à l'utilisateur d'hériter pour ses propres classes de simulation du comportement de base d'un processus pouvant s'exécuter en mode dit « quasi-parallèle », à l'aide du concept de coroutine.

Une coroutine est une routine à plusieurs points de sortie et qui, à chaque ré-entrée du flot d'exécution dans celle-ci lors d'un appel à l'instruction Resume, reprend son exécution à la dernière instruction où le flot l'avait précédemment quittée lors d'un appel à l'instruction Detach. Le point d'exécution est stocké dans le LSC : Local Sequence Counter.

Pour clarifier le propos, le programme suivant produirait l'affichage indiqué plus bas :

 Begin
  Ref(TwinProcess) firstProc, secondProc;
  Class TwinProcess(Name); 
  Text Name;
  Begin
        ! Initial coroutine entry (creation)
     Ref(TwinProcess) Twin;
     OutText(Name); OutText(": Creation"); OutImage;
        ! First coroutine exit
     Detach;
        ! Second coroutine entry
     OutText(Name); OutText(": Second coroutine entry"); OutImage;
         ! Second coroutine exit: switch to the twin's coroutine
     Resume(Twin);
         ! Last coroutine entry
     OutText(Name); OutText(": Last coroutine entry"); OutImage;
     Resume(Twin);
  End;
  Begin
     firstProc :- New TwinProcess ("1st Proc");
     secondProc :- New TwinProcess ("2nd Proc");
     firstProc.Twin :- secondProc;
     secondProc.Twin :- firstProc;
     OutText("Starting"); OutImage;
     Resume(firstProc);
     OutText("End");
  End;
 End;

Affichage :

 1st Proc: Creation
 2nd Proc: Creation
 Starting
 1st Proc: Second coroutine entry
 2nd Proc: Second coroutine entry
 1st Proc: Last coroutine entry
 2nd Proc: Last coroutine entry
 End

La bibliothèque de simulation discrète permettait de gérer la file des processus au moyen d'instructions dédiées (Activate, Passivate, Hold, etc.)

Programmation objet

La plupart des constructions qui permettront plus tard la réalisation des concepts principaux de la programmation orientée objet sont d'ores et déjà présents dans Simula 67 :

  • les classes comme structure de donnĂ©es dans Simula rassemblant variables et opĂ©rations sur ces dernières (dans Simula, il reprĂ©sentaient des activitĂ©s),
  • l'instanciation via l'instruction New,
  • les relations entre objets (ou processus dans le jargon originel de Simula) au moyen de rĂ©fĂ©rences : Ref( ) et affectation de rĂ©fĂ©rences avec l'instruction :-
  • rĂ©fĂ©rence sur l'instance courante grâce au mot clĂ© This
  • Test de rĂ©fĂ©rence nulle automatique nativement supportĂ© Inspect-Do-Otherwise : Inspect rect do Draw. Ici, x.Draw ne sera appelĂ© que si x n'est pas une rĂ©fĂ©rence nulle (mot clĂ© : None)
  • fonctions virtuelles
  • appel de mĂ©thode par notation pointĂ©e (dot-notation) : <objet>.<mĂ©thode>
  • appel qualifiĂ© (i.e. statiquement liĂ©) de mĂ©thodes virtuelles Ă  l'aide de l'opĂ©rateur Qua ou avec Inspect-When
  • reconnaissance de type Ă  l'exĂ©cution (instruction Inspect, Is, In)
  • hĂ©ritage simple entre classes
  • restriction d'accès (Hidden, Protected)
  • classes imbriquĂ©es (ou internes)
  • Imbrication sophistiquĂ©e des appels du corps de mĂ©thode de la classe via l'instruction Inner, qui peut ainsi permettre d'obliger l'exĂ©cution de code avant et/ou après l'exĂ©cution du corps d'une classe dĂ©rivĂ©e : on voit dĂ©jĂ  se profiler le concept d'assertions, implĂ©mentĂ©es par Eiffel dans les annĂ©es 1980, ou mĂŞme la programmation par aspect, qui sera dĂ©veloppĂ©e dans les annĂ©es 1990.
  • un ramasse-miettes en anglais : garbage-collector.

Cette liste succincte permet de prendre conscience de la percée conceptuelle opérée par Simula en 1967 dans le domaine des langages impératifs structurés.

Malheureusement, les auteurs de Simula apportèrent une certaine confusion dans le monde de la programmation orientée objet. À l'apparition de ce nouveau paradigme avec Smalltalk, Ole Johan Dahl et Kristen Nygaard changèrent les dénominations utilisées dans Simula pour se conformer aux concepts véhiculés dans Smalltalk (classes d'objets, objets, attributs, méthodes, etc.) et déclarèrent que Simula 67 était en fait le premier langage orienté objet. Pourtant, l'approche utilisée dans Simula 67 n'est pas celle définie par Alan Kay, l'auteur de la programmation orientée objet.

Voir aussi

Articles connexes

Liens externes

  • (en) Introduction to OOP in Simula – par J.Sklenar, basĂ© sur le sĂ©minaire de 1997 « 30 Years of Object Oriented Programming (OOP) » de l'UniversitĂ© de Malte
  • (en) How Object-Oriented Programming Started – par Dahl et Nygaard, version abrĂ©gĂ©e d'un article d'une encyclopĂ©die sur la page du site de Nygaards.
Cet article est issu de wikipedia. Text licence: CC BY-SA 4.0, Des conditions supplémentaires peuvent s’appliquer aux fichiers multimédias.