介绍

go语言工具箱具有十分强大的功能,支持我们编译,安装与下载包。

使用命令go env就能查看当前go的所有环境:

本文中只讨论传统的GOPATH配置自定义包的模式,不过现在已经支持GO MOD了,可以很好的解决包之间的依赖与构建问题,若要采用GOPATH配置包则需要关闭GO111MODULE:
Windows:
set GO111MODULE=off
Linux:
export GO111MODULE=off

GOPATH是我们go语言的工作目录,go get下载的依赖包会下载到该目录下,该目录结构如下所示:

其中src为源码安装目录,pkg为包编译好后链接文件存的路径(*.a),bin则是存放包中的可执行文件。在使用go get package 命令获取包后,采用go install package则进行编译与安装,将.a文件放入pkg目录下,将执行文件放入bin目录下。如果我们想安装自己定义的包同样是这个步骤,如果不想使用默认的GOPATH可自行更改,在命令行中临时更改命令如下:
Windows:
set GOPATH=“your path”
Linux:
export GOPATH=“your path”

示例

我们在上述的src目录下新建目录test_pkg,目录结构如下:

add.go

  package libs
  
  func Add(a, b int64) int64 {
      return a + b
  }

main.go

  package main

  import (
          "fmt"
          "os"
          "strconv"
          "test_pkg/tools"
  )

  func main() {
          if len(os.Args) != 3 {
                  fmt.Println("args error...")
                  return
          }
          var err error
          var a, b int64
          a, err = strconv.ParseInt(os.Args[1], 10, 64)
          b, err = strconv.ParseInt(os.Args[2], 10, 64)

          if err != nil {
                  fmt.Println(err)
                  return
          }
  
          fmt.Println(tools.Add(a, b))
  }

build&install

当包下存在main包时,会生成以该main包为入口的包可执行文件:

再次go install后得到:

bin目录下出现该可执行文件,可在命令行中直接使用:

无main包时则编译该包下的库,如下:

在pkg目录下有:

windows_amd64为机器型号,生成的test_pkg可直接在*.go中直接使用。
下一篇博客中将会详细梳理GO Mod的使用。