Identifiant :
Mot de passe :

Patrons de conception

Changement dynamique d'état

Enoncé du problème :

Modéliser le fonctionnement d'une vidéothèque. La vidéothèque met à disposition de ses clients des DVD selon trois catégories : Enfant, Normal et Nouveauté. Un DVD est dans la catégorie Nouveauté pendant quelques semaines, puis passe dans l'une des autres catégories. Le prix des DVD dépend de la catégorie. Il est probable que le système évolue pour que la catégorie Horreur soit ajoutée.

Solution optimale :

Diagramme de classes :

Diagramme de classes

Thanks to the inheritance links, we are able to distinct the DVD to its states. In these case, the addition of a new state does not imply code modification.

Solution alternative 1 :

Diagramme de classes :

Diagramme de classes

The category is a subclass of DVD imposing instances destruction to change of category. The question of the validity of this solution is open in regard of the proposed exercise. However, we have considered this solution valid in using a prototype creational pattern with a category as parameter.

Cliquez ici pour voir le patron abîmé déduit de cette solution alternative

Solution alternative 2 :

Diagramme de classes :

Diagramme de classes

The DVD class manages its state thanks to an enumeration. In doing so, the solution imposes a ``switch'' statement, and so, the category changing is possible. The problem of this solution concerns the extensibility. Indeed, if a new category is added, the DVD class must be modified to manage the new type.

Cliquez ici pour voir le patron abîmé déduit de cette solution alternative

Les têtes de mule
Cédric BOUHOURS
Cédric BOUHOURS
Cédric BOUHOURS