>백엔드 개발 >Golang >XP를 지원하는 Go 언어 버전

XP를 지원하는 Go 언어 버전

青灯夜游
青灯夜游원래의
2022-12-14 19:02:246988검색

go 언어의 "1.10" 버전은 XP 시스템을 지원합니다. Golang1.10은 Windows XP/2003을 지원하는 마지막 버전이므로 Golang으로 컴파일된 프로그램을 WinXP/2003에서 실행하려면 Golang1.10을 다운로드해야 합니다. 이후 버전에는 최소한 Win7/2008 운영 체제가 필요합니다.

XP를 지원하는 Go 언어 버전

이 튜토리얼의 운영 환경: linux7.3 시스템, GO 버전 1.18, Dell G3 컴퓨터.

Go 언어 개발 버전


Go 언어 프로그램의 개발은 주로 golang 컴파일러에 의존합니다. 컴파일러는 GC(Go Compiler)와 GCCGo로 구분됩니다. 현재 golang에서 공식적으로 다운로드할 수 있는 GC 버전은 GCC 조직에서 관리하는 GCCGo입니다.

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) Compiler

코드를 바이너리 실행 파일로 컴파일하는 명령 도구입니다. 사실 여기서는 "빌더"라고 부르는 것이 더 적절합니다. 코드를 작성한 후 "go build" 명령을 입력하면 코드를 실행 파일로 직접 "컴파일"하고 "링크"할 수 있기 때문입니다.

'컴파일'과 '링크'라는 용어의 정의는 C 언어에서 유래했습니다.

C 언어 코드는 고정된 형식에 따라 고정된 어휘로 구성되어 있어 간단하고 직관적이며 프로그래머가 인식하고 이해하기 쉽습니다. 그런데 CPU의 경우 C언어 코드는 성경을 전혀 모른다. CPU는 바이너리 형식의 명령어만 몇백 개만 알고 있다. 이를 위해서는 C 언어 코드를 CPU가 인식할 수 있는 바이너리 명령어로 변환하는 도구가 필요합니다. 이 도구는 컴파일러라는 특수 소프트웨어입니다.

C 언어 코드가 컴파일된 후 최종 실행 파일(.exe 파일)을 생성하지 않고, 객체 파일(Object File)이라는 중간 파일(또는 임시 파일)을 생성합니다. 대상 파일도 실행 파일과 동일한 형식을 갖는 바이너리 형식입니다. Visual C++의 경우 개체 파일 접미사는 ​​.obj이고 GCC의 경우 개체 파일 접미사는 ​​.o입니다.

대상 파일은 연결 후 실행 파일이 될 수 있습니다. 대상 파일과 실행 파일의 형식이 동일한데 왜 다시 링크해야 실행 파일로 바로 사용할 수는 없나요?

말도 안돼! 컴파일은 우리가 작성한 코드를 바이너리 형식으로만 변환하기 때문에 프로그램 실행에 필요한 시스템 구성요소(예: 표준 라이브러리, 동적 링크 라이브러리 등)와도 결합되어야 합니다.

Link는 실제로 모든 대상 파일과 시스템 구성 요소를 바이너리 형식으로 결합하여 실행 파일로 만드는 "패키징" 프로세스입니다. 연결 프로세스를 완료하려면 링커라는 특수 소프트웨어도 필요합니다.

(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

이 때 시스템에는 다음과 같은 출력이 표시됩니다.

XP를 지원하는 Go 언어 버전

Build


如果每次都通过go run去执行程序,则需要在发布程序时需要带上golang的运行时环境。这显然是不能满足要求的。可以将程序直接构建为可执行文件。

键入如下命令:

go build

此时,会在当前目录下产生一个helloworld的可执行文件

XP를 지원하는 Go 언어 버전

运行这个文件,会得到与go run 相同的结果。

./helloworld

XP를 지원하는 Go 언어 버전

使用扩展包


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会自动下载依赖包

XP를 지원하는 Go 언어 버전

同时,生成了名为“mongodemo”的可执行文件

执行该文件,输出了mongodb中的查询结果

XP를 지원하는 Go 언어 버전

更多编程相关知识,请访问:编程视频!!

위 내용은 XP를 지원하는 Go 언어 버전의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.