- Système structural de types
-
En Programmation informatique, un système structurel de types est une classe majeure de système de types, dans laquelle la compatibilité et l'équivalence de type est déterminée par la structure du type et non par des déclarations explicites. On utilise les systèmes structuraux pour déterminer si les types sont équivalents, ou si un type est un sous-type d'un autre. Ce système est en opposition avec les systèmes nominatifs où les comparaisons sont basées sur des déclarations explicites ou sur le nom des types.
Avec le typage structurel deux objets ou termes sont considérés comme ayant des types compatibles si leurs types ont une structure identique. Selon la sémantique du langage, cela signifie généralement que pour chaque fonctionnalité dans un type il doit y voir une fonctionnalité correspondante dans l'autre type. Les détails changent selon les langages. Ainsi sur le fait que deux fonctionnalités doivent avoir le même nom pour être considérées identiques.
Haskell et ML sont deux langages au typage structurel. Haxe est un langage au typage structurel bien que ses classes ne soient pas structurellement sous-typées.
Dans les langages qui supportent le sous-typage polymorphique, on peut former une dichotomie similaire pour définir une relation de sous-type. Un type est un sous-type d'un autre si et seulement il contient toutes les fonctionnalités du type de base ou de l'un de ses sous-types. Le sous-type peut contenir des fonctionnalités additionnelles telles que des membres non présents dans le type de base ou des invariants plus forts.
Le sous-typage structurel est plus flexible que le sous-typage nominal, car il permet la création de types et d'interfaces ad hoc. Il permet en particulier la création d'un type qui est un super-type d'un type existant
T
sans modifier la définition deT
. Mais cela peut ne pas être désirable quand un programmeur veut créer des abstractions fermées.Le piège du typage structurel comparé au typage nominal est que si deux types définis séparément pour des buts différents, chacun consistant en une paire de nombres sont considéres du même type par le système de type, simplement parce qu'ils ont une structure identique, Une manière d'éviter cela est de créer un type algébrique pour un type de paire et un autre pour l'autre type de paire.
Duck typing
Un système intéressant de type qui se comporte de manière similaire au sous-typage structurel est le duck typing. Le ducktyping n'est pas un vrai système de types car il est implanté dans des langages dynamiquement typés qui n'effectuent pas de jugement de type à la compilation. Mais c'est un système populaire car il offre une grande flexibilité au programmeur, tout en préservant la possibilité de générer des abstractions fermées.
Liens externes
Wikimedia Foundation. 2010.