Coroutine

Dans le monde d'aujourd'hui, Coroutine est devenu un sujet d'une grande pertinence et d'un grand intérêt pour un grand nombre de personnes. Que ce soit en raison de son impact sur la société, de sa pertinence historique ou de son influence sur divers aspects de la vie quotidienne, Coroutine a retenu l'attention d'un large public. De ses origines à son évolution actuelle, Coroutine continue de générer des débats, des réflexions et des analyses approfondies. Dans cet article, nous explorerons différents aspects liés à Coroutine, dans le but d'approfondir son importance et de mieux comprendre son impact sur le monde moderne.

En informatique, dans un programme, une coroutine est une unité de traitement qui s'apparente à une routine, à ceci près que, alors que la sortie d'une routine met fin à la routine, la sortie de la coroutine peut être le résultat d'une suspension de son traitement jusqu'à ce qu'il lui soit signalé de reprendre son cours. La suspension de la coroutine et la reprise de son cours peuvent s'accompagner d'une transmission de données.

Les coroutines permettent de réaliser des traitements basés sur des algorithmes coopératifs comme les itérateurs, les générateurs, des canaux de communication, etc.

Histoire

D'après Donald Knuth, le terme coroutine fut inventé par Melvin Conway en 1958, alors qu'il travaillait à l'écriture d'un programme assembleur[1]. Plus tard, Conway proposa d'organiser un compilateur en un ensemble de coroutines, ce qui donne la possibilité d'utiliser des chemins différents lors du débogage, et d'utiliser une seule structure en production[2].

Exemples

Références

  1. (en) Knuth, Donald Ervin (1997). Fundamental Algorithms. The Art of Computer Programming. 1 (3rd ed.). Addison-Wesley. Section 1.4.5: History and Bibliography, pp. 229. (ISBN 0-201-89683-4).
  2. (en) M.E. Conway, "Design of a separable transition-diagram compiler", Communications of the ACM, Vol. 6, No. 7, juillet 1963.