往期回顾:
- Go语言开发小技巧&易错点100例(一)
**本期看点(技巧类用【技】表示,易错点用【易】表示)**:
(1)Go Module中对依赖库版本的升级与降级【技】
(2)Go goroutine中的异常处理【易】
(3)Go中slice作为参数是值传递【技】
正文:
1 Go Module中对依赖库版本的升级与降级【技】
Go Module引用其他的依赖库分为两种方式:
- 引用该库的某一个tag
- 引用该库的某一个分支(称之为伪版本)
因而显示上也会有差别(大多数情况下),如下:
github.com/coreos/go-semver v0.3.0 //引用tag
github.com/coreos/go-systemd v0.0.0-20191104093116-d3cd4ed1dbcf //引用分支
但是不管是引用tag还是引用分支,指向的都是该仓库的分支或tag提交最后一个commit时的镜像,因而版本的升级与降级的最小颗粒度就是commit
先看针对tag进行升降级:
# 查看该依赖库的所有版本
go list -m -versions github.com/xuri/excelize/v2
# 输出:
github.com/xuri/excelize/v2 v2.0.0 v2.0.1 v2.0.2 v2.1.0 v2.2.0 v2.3.0 v2.3.1 v2.3.2 v2.4.0 v2.4.1 v2.5.0 v2.6.0 v2.6.1
# 查看当前项目依赖库的版本
go list -m github.com/xuri/excelize/v2
# 输出:
github.com/xuri/excelize/v2 v2.6.1
# 指定想要切换到的版本
go get github.com/xuri/excelize/[email protected]
# 输出:
go: downloading github.com/xuri/excelize/v2 v2.6.0
go get: downgraded github.com/xuri/excelize/v2 v2.6.1 => v2.6.0
**针对分支或commit升降级(前提是知道之前一个commit的伪版本信息)**:
比如你之前一个引用的commit是
github.com/coreos/go-systemd v0.0.0-20191104093116-d3cd4ed1dbcf
目前是:
github.com/coreos/go-systemd v0.0.0-20191104093116-d3cd4ed1dbcf
想要切换回去,可能go get就不是很管用了,那么就需要使用新的方式:
replace github.com/coreos/go-systemd => github.com/coreos/go-systemd v0.0.0-20191104093116-d3cd4ed1dbcf
v0.0.0-[主干分支最新一次commit的时间]-[commit哈希值]