


go build ne fonctionne pas lorsqu'il est utilisé avec un espace de travail
l'éditeur php Banana est là pour vous présenter un problème courant, c'est-à-dire que la commande go build ne peut pas fonctionner correctement lors de l'utilisation de l'espace de travail. Ce problème peut dérouter les développeurs, car l'espace de travail est un concept très important dans le langage Go, et l'incapacité d'utiliser correctement la commande go build affectera sérieusement le processus de développement. Dans l'article suivant, nous analyserons en profondeur la cause de ce problème et proposerons des solutions pour aider les développeurs à résoudre ce problème avec succès.
Ce qui suit est la structure de mon code golang,
├── go.work ├── moda │ ├── go.mod │ └── main.go ├── go.mod └── modb └── main.go
Le problème est que je ne peux créer des binaires que pour un seul module. Pour construire d'autres modules, cela ne fonctionne que si je commente les autres modules dans go.work
Mon go.work est le suivant,
go 1.19 use ( ./moda . )
Donc, lorsque j'utilise go.work ci-dessus pour construire comme suit, cela fonctionne bien,
go build -o test-binary -modfile ./moda/go.mod ./moda
Mais lorsque j'essaie de construire pour mon autre module (c'est-à-dire modb/) comme indiqué ci-dessous,
go build -o test-binary1 -modfile ./go.mod ./modb
J'ai rencontré l'erreur suivante,
directory modb is contained in a module that is not one of the workspace modules listed in go.work. you can add the module to the workspace using go work use .
J'ai essayé d'utiliser go 工作 use
mais je suis toujours confronté au même problème. Quelqu'un peut-il m'aider à résoudre ce problème ?
Edit 1 :
J'avais un projet qui nécessitait plusieurs fichiers go.mod pour séparer les dépendances du module principal et des sous-modules, et c'est à ce moment-là que j'ai commencé à découvrir les espaces de travail go qui convenaient très bien à mon cas d'utilisation.
La structure de mon projet est la même que celle mentionnée ci-dessus,
├── go.work ├── submodule │ ├── go.mod │ ├── go.sum │ └── main.go └── mainmodule └── main.go ├── go.mod ├── go.sum
Maintenant, lors de la construction de l'exécutable d'un sous-module, go build fonctionne correctement, mais lors de la construction de l'exécutable du module principal, les importations présentes dans le sous-module/go.mod sont également ajoutées à l'exécutable du module principal. J'ai vérifié cela avec go build -n
aussi.
Pour éviter d'ajouter des importations de sous-modules à l'exécutable du module principal, j'ai utilisé -modfile
mais en l'utilisant, je ne peux construire l'exécutable que pour le sous-module et non pour le module principal.
code source de github
ps : Bien que j'ai ajouté un exemple de code dans github, je ne peux pas reproduire le même problème (les importations de sous-modules sont ajoutées au module principal) Je ne sais pas si c'est à cause des importations que j'ai utilisées
Bonne réponse
Après en discutant avec @arigatomanga, nous avons découvert que la confusion est causée par la sélection de version minimale (mvs) dans l'espace de travail. Un espace de travail est une collection de modules sur disque qui est utilisée comme module principal lors de l'exécution de Sélection de version minimale (mvs) (Référence). Grâce à mvs, les modules construits avec le mode espace de travail activé peuvent utiliser des modules dépendants différents de ceux construits avec le mode espace de travail désactivé.
Il s'agit du comportement documenté de l'espace de travail et il n'y a aucun problème pour le moment.
Mise à jour : vous trouverez ci-dessous la réponse originale, axée sur le drapeau -modfile
. En mode espace de travail dans go1.21, cet indicateur sera rejeté.
Vous avez rencontré une erreur dans l'outil go. Je viens de signaler ce problème ici.
Le message d'erreur dans go1.20 est différent et toujours trompeur :
go: module example.com/m1 appears multiple times in workspace
La différence a été introduite par le commit cmd/go/internal/modload : erreur renvoyée lors de la duplication des chemins de module entre les modules dans go.work, mais la cause première est la même : en mode espace de travail, l'indicateur -modfile
n'a pas été corrigé. .
Mise à jour : la section suivante n'est pas pertinente pour le moment. Avant de comprendre ce qu'est mvc, essayer de supprimer mvs en utilisant le drapeau -modfile
est une tentative ratée.
Dans le rapport de problème, j'ai suggéré de bloquer le drapeau -modfile
en mode espace de travail. Mais vous avez dit dans les commentaires que vous aviez besoin de ce drapeau.
La raison d'utiliser -modfile
的原因是如果我为 ./src
构建二进制文件,即使在 ./moda
中存在的模块也会作为 ./src
est que si je construis un binaire pour ./src
, même les modules présents dans ./moda
apparaîtront comme ./src code> est téléchargé et chargé dans le cadre du binaire, bien qu'il ne doive pas être inclus
Mais selon la documentation cmd/go :
-fichier modfile
En mode compatible avec les modules, lisez (et éventuellement écrivez) un go.mod alternatif fichier au lieu d’un fichier dans le répertoire racine du module. Une personne nommée "go.mod" doit toujours exister pour déterminer la racine du module répertoire, mais le répertoire n'a pas été consulté. Lorsque -modfile est spécifié, Utilise également un autre fichier go.sum : son chemin est dérivé de -indicateur modfile, en supprimant l'extension ".mod" et en ajoutant ".sum".
L'indicateur-modfile
标志用于替换模块根目录中的 go.mod
est utilisé pour remplacer le fichier go.mod
dans le répertoire racine du module. Mais dans votre exemple, vous avez spécifié le même fichier que celui de la racine du module. Donc je ne comprends pas très bien. Pouvez-vous mettre à jour votre question pour développer cette partie ? La démo est occupée !
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

La bibliothèque utilisée pour le fonctionnement du numéro de point flottante dans le langage go présente comment s'assurer que la précision est ...

Problème de threading de file d'attente dans Go Crawler Colly explore le problème de l'utilisation de la bibliothèque Crawler Crawler dans le langage Go, les développeurs rencontrent souvent des problèmes avec les threads et les files d'attente de demande. � ...

La différence entre l'impression de chaîne dans le langage go: la différence dans l'effet de l'utilisation de fonctions println et string () est en Go ...

Le problème de l'utilisation de Redessstream pour implémenter les files d'attente de messages dans le langage GO consiste à utiliser le langage GO et redis ...

Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Lorsque vous utilisez Goland pour le développement du langage GO, de nombreux développeurs rencontreront des balises de structure personnalisées ...

Quelles bibliothèques de GO sont développées par de grandes entreprises ou des projets open source bien connus? Lors de la programmation en Go, les développeurs rencontrent souvent des besoins communs, ...

Deux façons de définir les structures dans le langage GO: la différence entre les mots clés VAR et le type. Lorsque vous définissez des structures, GO Language voit souvent deux façons d'écrire différentes: d'abord ...

Lorsque vous utilisez SQL.Open, pourquoi le DSN ne signale-t-il pas une erreur? En langue go, sql.open ...
