Go 语言在依赖包管理一共经过三个重要阶段:仓库模式、vendor、modules,关于这三个模式在另一篇文章中有详细介绍。
新的 Go 项目往往采用了 go modules 管理包依赖,不需要关注项目放置的位置,根据项目根路径的 go.mod 文件去读取加载依赖内容。
由于历史项目的特殊性,比如以及上线运营,评估升级风险过高等原因会要求基于旧的版本持续维护。
对于旧项目、历史项目,如果直接导入到本地 GoLand 之后往往会出现全面飘红或者某些依赖飘红,这时候就要关注一些早期版本的内容了。
Go 在 1.5 版本以前,GOPATH 是一个非常重要的环境变量。
它将标识着代码编译时去寻找实际代码所在的位置,一般从 $GOPATH/src 下寻找代码。
在处理旧项目飘红的整个处理过程往往就是围绕着 GOPATH 来处理的。
对于历史项目而言,我们优先考虑将项目放到 GOPATH/src 目录下。
首先查看你的公共 GOPATH 配置,如果没有的话建议创建一个,这个环境变量 GoLand 也能够读取到。
历史项目建议直接移到 $GOPATH/src 目录下,src 目录不存在的话可以手工建一个。
为什么要放在 src 下呢?
因为 GOPATH 下存在三个功能目录(约定目录):
注意:GOPATH可以配置多个,一般多用于特殊情况下(比如同项目多版本并行开始),正常避免混乱,建议配置一个习惯的目录即可。
如果只是单纯不想放在 /src 下,少年!我劝你耗子尾汁!
但是对于某些特殊的项目,比如其依赖的某个包的版本比较特殊,其他大部分项目用的是别的版本,这时候可以考虑 Project GOPATH。
GoLand 提供了一个 Project GOPATH 配置项,可以理解为项目级的 GOPATH 环境变量配置,仅仅对当前项目生效。
你可以将具体项目的位置配置进来,该配置也均需约定目录的规则,相当于增加一个独立的 GOPATH 位置。
Project GOPATH 和 直接配置多个系统 GOPATH 还是有很大区别的:
形象一点来说是一个私有化的 GOPATH,只有自己可以使用和访问。
正常来说,只要代码放在 $GOPATH/src 目录下,使得编译器能够寻找到,几乎可以解决所有问题。
这里记录一个有趣的案例。
实际上最终还是没有脱离 $GOPATH/src 的问题。
导入一个旧工程发现,main.go 中 import 飘红,发现子目录下确实存在一个叫 run 的包,但是就是导入不进来,为什么?
答:依照 import 的 URL 相对于 src 目录调整一下项目的外部目录结构(归根结底还是编译器在 src 下找不到对应的代码所致)。
当前还没有观点发布,欢迎您留下足迹!
在 Go 中函数可以接受值传递和指针传递,使用时就涉及到 & 内存地址(指针)与 * 指针赋值的使用,它们的区别是什么?在实际业务使用中,值传递和指针传递的分别应对什么场景需要?针对使用时机进行分析。
GoLand 在保存代码时,可以自动调用 gofmt 和 goimports 实现自动格式化代码,在新版本中可以通过 File Watchers 插件来完成这些配置,配置位置位于File
Go1.11版本开始支持包依赖管理工具,新增了GOPROXY环境变量,用于配置依赖包下载代理,通过代理配置可以实现翻墙下载一些所需的依赖包,可以说相当实用
Go 中比较常见的 int、string、bool、float 基本数据类型之外还有其他的数据类型可以应用在特殊场景,比如 rune 就是类似于 int32,因为其可表示的字符范围更大,实际工作中可以用来计算字符串的真实长度
调试 Go 程序报错 xx is shadowed during return,方法在返回的时候不是预期的返回结果,错误的产生应当是在相同作用域中出现了同名的变量导致,根据实际业务场景进行修改
Go语言中的接口采用的是隐式实现,不需要去申明实现,只需要直接实现接口所定义的全部方法即可,同时区分了直接实现与指针实现两种形态,在实际使用时需要注意和关注