目录一、获取生成时间1.使用Go编译时的链接参数来指定生成时间2.使用C语言获取生成时间二、获取git版本信息三、获取Go的相关信息我们在编写软件时,一般会有版本号以及生成的时间,G
我们在编写软件时,一般会有版本号以及生成的时间,Go编译的程序中,如何添加当时的编译时间以及版本信息?
C/C++语言,非常方便,可以直接使用__DATE__宏即可知道生成时间,但是Go语言没有。既然Go语言没有, C语言有,那我们可以直接使用CGO来使用C语言的功能。当然也可以使用Go的编译链接参数来指定,只是这种方式不适用于windows。
假如有如下Go源码:
package main
var BuildTime string
func main() {
fmt.Printf("Build Time: %s\n", BuildTime )
}
使用Go的编译参数:
-ldflags -X importpath.name=value
来设置。
在linux、MinGW、Cygwin、MacOS的Bash中可以使用如下指令来指定生成的时间信息:
go build -ldflags "-X 'main.BuildTime=`date +'%Y-%m-%d %H:%M:%S'`'" -o main.exe
但是在Windows的命令行中不能正常工作,包括在Windows的Goland中也不能正常工作。
由于C语言__DATE__宏是使用的英文字母表示的月份,为了方便、直观,这里在Go语言中改为阿拉伯数字来表示,并改为年-月-日 时:分:秒的数字表现形式。
生成时间一经生成是不会变的,所以在Go语言中只需要获取一次即可,如果有值了,则直接返回。
直接上代码:
package ver
import "C"
import (
"fmt"
"strings"
)
var buildTime string
func GetBuildTime() string {
if buildTime != "" {
return buildTime
}
date := C.GoString(C.GetCompileDate())
tm := C.GoString(C.GetCompileTime())
strMonth := []string{"Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Sep", "Dec"}
arStr := strings.Split(date, " ")
for i, s := range strMonth {
if s == arStr[0] {
buildTime = fmt.Sprintf("%s-%02d-%s %v", arStr[2], i+1, arStr[1], tm)
break
}
}
return buildTime
}
由于使用了CGO,所以需要安装有GCC编译器。这种方式在Windows与Linux下都可以使用。
git获取版本信息的指令为git show -s --fORMat=%H,可以使用Go来执行然后获取返回结果即可。
代码如下:
package ver
import "os/exec"
var gitVer string
func GetGitVer() string {
if gitVer != "" {
return gitVer
}
Cmd := exec.Command("git", "show", "-s", "--format=%H")
out, err := Cmd.Output()
if err != nil {
return gitVer
}
gitVer = string(out[:len(out)-1])
return gitVer
}
由于Cmd返回的结果中有一个换行符\n,所以在获取后有把它去掉。
这就比较容易了,Go语言自带:
1. Go语言版本信息
runtime.Version()
2. 当前Go使用的操作系统信息
runtime.GOOS
3.当前GO使用的CPU指令架构信息
runtime.GOARCH
到此这篇关于Go项目中添加生成时间与版本信息的方法的文章就介绍到这了,更多相关Go添加生成时间与版本信息内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: Go项目中添加生成时间与版本信息的方法
本文链接: https://lsjlt.com/news/203313.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-04-05
2024-04-05
2024-04-05
2024-04-04
2024-04-05
2024-04-05
2024-04-05
2024-04-05
2024-04-04
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0