广告
返回顶部
首页 > 资讯 > 后端开发 > GO >go mode tidy出现报错go: warning: “all“ matched no packages的解决方法
  • 264
分享到

go mode tidy出现报错go: warning: “all“ matched no packages的解决方法

2024-04-02 19:04:59 264人浏览 独家记忆
摘要

目录解析检查1.本地的Go编译器版本2.go module构建模式未开启3. 是否在go.mod所在目录执行的go mod tidy总结 查到的可能原因:1.本地的go编译器版本2.

查到的可能原因
1.本地的go编译器版本
2. go module构建模式未开启
3. 是否在go.mod所在目录执行的go mod tidy

解析

一开始发布的时候 一开始go发布的时候是没有包管理的
go get命令会根据路径,把相应的模块获取并保存$GOPATH/src
也没有版本的概念,master就代表稳定的版本
后来引进了Go Module 在GO1.11引入,不再是只有一个版本了,利用go.mod记录每个包的版本

于是问题就来了


到底是按照$GOPATH的规则走还是按照Go Module来呢?

GO111MODULE是一个环境变量,用于改变go引入包的方式

Go1.11Go1.12

GO111MODULE=on
这个设置会强迫使用Go modules,即使项目在你的GOPATH里。需要go.mod才能工作。
GO111MOUDLE=off,使用GOPATH的方式,即使在GOPATH外边
GO111MODULE=auto,默认设置。

当你不在GOPATH内的时候,就类似GO111MODULE=on

当你在GOPATH内的时候,即使存在go.mod,也是GO111MODULE=off的效果

当你在GOPATH内,然后你需要GO modules来做一些操作的时候(如go get一个特定的版本),那就需要这么干:
GO111MODULE=on go get xxxxx


Go 1.13,auto的意思改变了: 如果找到了go.mod,或者在没有go.mod,但是在GOPATH外,那效果就是GO111MODULE=on(强迫使用go module)。所以你可以把所有的仓库都保存在你的GOPATH

why?
没有go.mod的时候,在GOPATH里,效果就是GO111MODULE=off(获取包并放在$GOPATH/src/)

检查

1.本地的go编译器版本

项目版本是1.16,这里有go.mod默认为GO111MODULE=on

2.go module构建模式未开启

保险起见

win

set GO111MODULE=auto

linux

export GO111MODULE=auto

果然没有用

go mod指令

3. 是否在go.mod所在目录执行的go mod tidy

发现是第三个原因

应该在douyinService下执行而不是DouYin

总结

到此这篇关于go mode tidy出现报错go: warning: “all“ matched no packages解决的文章就介绍到这了,更多相关go mode tidy报错解决内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: go mode tidy出现报错go: warning: “all“ matched no packages的解决方法

本文链接: https://www.lsjlt.com/news/120974.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作