Bonjour,
le titre est spécialement posé pour être provocateur
En fait mon problème est le suivant :
J'ai plusieurs classes fille d'une SuperClasse qui doivent chacune être créées en fonction d'une chaine identifiable par un pattern (mais ne comportant pas le nom de la classe) et contenant des paramètres; en simplifiant :
- "barbidule(1,2,3)" => Classe1 avec attributs initialisés à 1,2,3,
- "barbabulle(A,B)" => Classe2 avec attributs initialisés à A,B,
- "barbatruc" => Classe3 sans attributs
Comment faire ?
J'ai imaginé plusieurs solutions possibles :
- utiliser un constructeur acceptant la chaine et retournant une exception en cas d'incompatibilité ; la fabrique essayera toutes les classes jusqu'à tomber sur la bonne (mauvais selon moi puisqu'on détourne les exceptions, qui en plus sont coûteuses), mais la conception est plutôt simple
- utiliser une méthode de classe qui va nous dire si la classe peut être construite à partir de la chaine ; -> plus de soucis avec les exceptions, mais comment être sûr que les sous-classes implémentent bien la méthode de classe puisqu'on ne peut rendre ces méthodes abstaites au niveau de la super classe ? En plus impossible de faire du polymorphisme comme cela ! Seules les méthodes de réflexion sont capables de chercher une telle méthode sans poser problème.
- solution dérivée : une méthode getInstance(String) mais on a le même soucis avec l'héritage de méthode statique !
- dernière solution la plus propre : extraire la reconnaissance des chaines dans une fabrique, extraire les paramètres de la chaine proposée, puis construire la classe avec les bons paramètres directement (et plus avec la chaine), mais la reconnaissance est en dehors de la classe qui est censée être la seule au courant de la chose. On pourrait imaginer que ce soit la classe qui fournisse le pattern, mais on aurait encore le problème de la méthode qui doit absolument exister (donc issue d'une interface), mais du niveau classe et pas instance !
J'attends vos contre-propositions / critiques.
Merci à tous pour votre participation !
Partager