Malgré l'adoption de la composition plutôt que de l'héritage, le problème de la classe de base fragile peut toujours se poser à Go, bien que de manière moins grave. form.
Le problème se produit lorsque des modifications apportées à une classe de base brisent ses sous-classes. Dans les langages avec des méthodes virtuelles (comme Java), le remplacement des méthodes dans les sous-classes peut conduire à un comportement inattendu si la classe de base est modifiée.
Dans Go, cependant, il n'y a pas de polymorphisme (remplaçable méthodes). Lors de l'intégration d'un type, les méthodes intégrées sont promues dans la structure wrapper mais ne peuvent pas être remplacées. Cela atténue le problème de la classe de base fragile, car les méthodes promues ne peuvent pas être modifiées par les sous-classes.
En Java :
<code class="java">class Counter { int value; void inc() { value++; } void incBy(int n) { value += n; } } class MyCounter extends Counter { void inc() { incBy(1); } }</code>
Si Counter.incBy() est modifié plusieurs fois en inc(), MyCounter entrera dans une boucle infinie.
In Go :
<code class="go">type Counter struct { value int } func (c *Counter) Inc() { c.value++ } func (c *Counter) IncBy(n int) { c.value += n } type MyCounter struct { Counter } func (m *MyCounter) Inc() { m.IncBy(1) }</code>
Même avec la même modification à Counter.incBy() comme dans l'exemple Java, MyCounter fonctionnera toujours correctement, car il appelle directement Counter.Inc(). Les méthodes de la classe de base ne sont affectées par aucun changement dans la sous-classe.
Bien que le problème de la classe de base fragile soit moins répandu dans Go en raison de l'absence de polymorphisme, il est important de considérer le implications potentielles des changements de classe de base lors de l'intégration de types dans des structures.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!