go语言的“1.10”版本支持xp系统。golang1.10是最后支持windows xp/2003的版本,因此如果想要golang编译的程序可以在winxp/2003上运行,需要下载golang1.10;之后的版本则最低要求Win7/2008操作系统。
本教程操作环境:linux7.3系统、GO 1.18版本、Dell G3电脑。
Go语言开发的版本
Go语言程序的开发主要依赖于golang编译器。编译器分为GC(Go Compiler)和GCCGo。目前,golang官方可以下载的是GC版本,GCCGo则是由GCC组织维护。
golang1.10是最后支持windows xp/2003的版本,因此如果想要golang编译的程序可以在winxp/2003上运行,需要下载golang1.10。之后的版本则最低要求Win7/2008操作系统。
对于Linux操作系统而言,golang支持的最低内核版本为2.6.23。这对于Redhat 而言,至少是RHEL6.0(2.6.32-71);对于CentOS而言,至少是CentOS6.0(2.6.32-71);对于Oracle Linux而言,至少是OL5.6(2.6.32-100.26.2.el5uek);对于Ubuntu而言,至少是10.04;对于Suse Linux而言,至少是SLE11(Suse Linux Enterprise 11)。【相关推荐:Go视频教程、编程教学】
对于Unix而言,FreeBSD可以采用GC,但对于非x86处理器的操作系统而言,则需要采用GCCGo编译器。
进行Go语言开发的要素
(1)编译器
将代码编译为二进制可执行文件的命令工具。其实这里应该叫“构建器”更为合适。因为代码编写完成后,输入“go build”命令,可以直接将代码“编译”并“链接”为可执行文件。
术语“编译”与“链接”的定义来自于C语言
C语言代码由固定的词汇按照固定的格式组织起来,简单直观,程序员容易识别和理解,但是对于CPU,C语言代码就是天书,根本不认识,CPU只认识几百个二进制形式的指令。这就需要一个工具,将C语言代码转换成CPU能够识别的二进制指令,这个工具是一个特殊的软件,叫做编译器(Compiler)。
C语言代码经过编译以后,并没有生成最终的可执行文件(.exe 文件),而是生成了一种叫做目标文件(Object File)的中间文件(或者说临时文件)。目标文件也是二进制形式的,它和可执行文件的格式是一样的。对于 Visual C++,目标文件的后缀是.obj;对于 GCC,目标文件的后缀是.o。
目标文件经过链接(Link)以后才能变成可执行文件。既然目标文件和可执行文件的格式是一样的,为什么还要再链接一次呢,直接作为可执行文件不行吗?
不行的!因为编译只是将我们自己写的代码变成了二进制形式,它还需要和系统组件(比如标准库、动态链接库等)结合起来,这些组件都是程序运行所必须的。
链接(Link)其实就是一个“打包”的过程,它将所有二进制形式的目标文件和系统组件组合成一个可执行文件。完成链接的过程也需要一个特殊的软件,叫做链接器(Linker)。
(2)扩展包/组件
在进行程序编写的过程中,如果所有的“支持程序”或“工具类”都由开发人员从零开始实现,工作量会变得很大。因此要提高开发效率,大多数情况下会尝试寻找辅助程序开发的“扩展包”或“组件”。golang自带包管理工具,因此开发时可以按照具体需要通过命令下载扩展包。
(3)代码编写与调试
可以通过任何文本编辑器开发代码,然后通过GC编译器编译程序,当然也可以通过”go run”命令直接运行。如果需要调试程序,大多数情况下最为安全、稳妥、可信的方式是在程序中输出日志。如果非要单点调试,可以采用delve。
环境搭建
(1)下载并解压
cd usr/local wget https://golang.google.cn/dl/go1.15.6.linux-amd64.tar.gz tar xf go1.15.6.linux-amd64.tar.gz cd go
(2)创建软连接
ln -s usr/local/go/bin/go usr/local/bin/go
(3)示例:Hello world
cd usr/local/src mkdir -p go/helloworld cd go/helloworld/ vim main.go
输入如下代码:
package main import( "fmt" ) func main(){ fmt.Println("Hello world") }
保存退出,然后运行如下命令
go run main.go
此时,系统会有如下输出:
构建
如果每次都通过go run去执行程序,则需要在发布程序时需要带上golang的运行时环境。这显然是不能满足要求的。可以将程序直接构建为可执行文件。
键入如下命令:
go build
此时,会在当前目录下产生一个helloworld的可执行文件
运行这个文件,会得到与go run 相同的结果。
./helloworld
使用扩展包
golang的扩展包有多种不同的管理方式。比如传统的 go get 方式以及新推出对的go module方式。
对于go get方式,由于某些特殊原因,部分官方包无法从golang.org下载,因此需要采取手动下载与go get相结合的方式。
对于go module方式,由于可以采用goproxy代理的方式获取golang.org的基础包,因此完美解决了国内golang开发的难题。
然而go module只有1.13版本之后的golang才能支持。而1.13是不支持winxp/2003的。并且对于go get与go module而言,有关代码在引包的时候,写法多少有些不同。因此如果要开发兼容低版本操作系统的程序,仍然建议采用go get进行包管理。
这里只介绍通过go module管理包的方式
以读取mongodb数据为例,介绍如何使用go module引入mongodb客户端扩展包,并读取数据。
设置goproxy代理
go env -w GOPROXY=https://goproxy.cn,direct
创建项目目录,并初始化
mkdir -p go/mongodemo cd go/mongodemo/ go mod init mongodemo
此时,会在mongodemo目录下生成go.mod文件
然后编辑main.go,输入如下代码:
package main import ( "fmt" "log" "gopkg.in/mgo.v2" "gopkg.in/mgo.v2/bson" ) type cfg_host struct { Host string Cfg_data string } func main() { user := "用户名" password := "密码" port := "端口" ip := "localhost" url := fmt.Sprintf("mongodb://%s:%s@%s:%s",user,password,ip,port) session, err := mgo.Dial(url) if err != nil { panic(err) } defer session.Close() Optional. Switch the session to a monotonic behavior. session.SetMode(mgo.Monotonic, true) c := session.DB("db").C("cfg_hosts") var cfgs []cfg_host err = c.Find(bson.M{}).All(&cfgs) if err != nil { log.Fatal(err) } for _,item := range cfgs { fmt.Printf("%s\n",item.Host) fmt.Printf("%s\n",item.Cfg_data) } }
构建
go build
此时,go module
会自动下载依赖包
同时,生成了名为“mongodemo”的可执行文件
执行该文件,输出了mongodb中的查询结果
更多编程相关知识,请访问:编程视频!!
以上是go语言哪个版本支持xp的详细内容。更多信息请关注PHP中文网其他相关文章!