go语言支持xp的版本是什么
这篇“go语言支持xp的版本是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“go语言支持xp的版本是什么”文章吧。
go语言的“1.10”版本支持xp系统。golang1.10是最后支持windows xp/2003的版本,因此如果想要golang编译的程序可以在winxp/2003上运行,需要下载golang1.10;之后的版本则最低要求Win7/2008操作系统。
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)。
对于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
",item.Host)
fmt.Printf("%s
",item.Cfg_data)
}
}
构建
go build
此时,
go module
会自动下载依赖包同时,生成了名为“mongodemo”的可执行文件
执行该文件,输出了mongodb中的查询结果
相关文章