Gestion des versions de packages dans Go 1.5
Introduction
Le langage de programmation Go a été développé avec l'accent est mis sur la simplicité, mais même dans ce paradigme, il a été confronté à des défis en matière de gestion des versions de packages. Cet article explore les raisons de l'absence d'une méthode de gestion des versions de packages intégrée dans Go et présente la solution introduite dans Go 1.5, connue sous le nom de vente.
Contexte historique
L'absence d'un système de gestion des versions de packages intégré dans Go découle d'un désir de maintenir la simplicité. Cette décision a été prise en partant du principe que les utilisateurs préféreraient la facilité de récupérer uniquement la dernière version d'un package. Cependant, les inconvénients de cette approche sont devenus évidents car les utilisateurs ont rencontré des difficultés à gérer les conflits avec les dépendances transitives.
Défis liés à la gestion des dépendances
Sans gestion des versions des packages, les développeurs étaient obligés de créer des référentiels séparés pour les modifications majeures de version de leurs produits, ce qui entraîne des inefficacités et une visibilité réduite sur l'historique du package. De plus, cela empêchait la rétrogradation entre les versions mineures ou micro pour résoudre les bogues, car la chaîne d'outils officielle ne prend en charge que la récupération de la dernière version.
Vente dans Go 1.5
Pour résoudre ces problèmes limitations, la vente a été introduite en tant que fonctionnalité expérimentale dans Go 1.5. Cette solution permet aux utilisateurs de garder un contrôle précis sur les versions des packages externes utilisés dans leur code.
Mécanisme de vente
La vente fonctionne en créant un dossier fournisseur au sein du projet annuaire. Ce dossier contient des copies exactes des packages externes requis, garantissant que le projet utilise des versions spécifiques, même si les packages ont été mis à jour en externe. Lors de l'importation de packages à partir du répertoire du fournisseur, le chemin d'importation omet l'élément du fournisseur, car il est traité comme le dossier workspace/src.
Exemple
Considérez l'exemple suivant :
/home/user/goworkspace/ src/ mymath/ mymath.go vendor/ github.com/somebob/math math.go
Dans ce scénario, le package mymath dépend du github.com/somebob/math externe emballer. Pour importer ce package dans mymath.go, la syntaxe suivante serait utilisée :
import "github.com/somebob/math"
Cette approche garantit que mymath importe la version spécifique de github.com/somebob/math qui se trouve dans le répertoire du fournisseur.
Conclusion
La vente dans Go 1.5 offre une solution précieuse aux défis de gestion des versions de packages. En permettant aux développeurs de maintenir un contrôle précis sur les versions externes des packages, la vente réduit les risques, améliore l'efficacité et facilite l'adoption de Go par les entreprises.
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!