GOPATH与工作空间
GOPATH设置
go 命令依赖一个重要的环境变量:$GOPATH
在go 1.8以前,此环境变量需要用户必须进行设置。但是在go 1.8版本以后,在没有设置情况下,会有一个默认值。
其在Unix/Linux/macOS下是:$HOME/go
这个目录,在Windows下是:%USERPROFILE%/go
这个目录。
在 Unix/Linux/macOSX GOPATH 环境可以这样设置:
export GOPATH=/home/apple/mygo
为了方便,应该把以上一行加入到.bashrc
或者.zshrc
或者自己的shell
的配置文件中。
Windows 设置如下,新建一个环境变量名称叫做GOPATH:
GOPATH=c:\mygo
GOPATH允许多个目录,当有多个目录时,请注意分隔符。 Windows是分号;
、而Linux/Unix/MacOSX系统是冒号:
。
当有多个GOPATH时,默认会将go get
的内容放在第一个目录下。
以上$GOPAT目录约定有三个子目录:
- src 存放源代码(比如:.go .c .h .s等)
- pkg 编译后生成的文件(比如:.a)
- bin 编译后生成的可执行文件(为了方便,可以把此目录加入到
$PATH
变量中)
以后我所有的例子都是以mygo作为我的GOPATH目录
应用目录结构
GOPATH 下的src目录就是接下来开发程序的主要目录,所有的源码都是放在这个目录下面。
一般我们的做法就是一个目录一个项目,例如: $GOPATH/src/mymath
表示mymath这个应用包或者可执行应用。
应用类型是根据入口package是main还是其他名称来决定:
- main的话就是可执行应用,
- 其他的话就是应用包
这个会在后续详细介绍package。
以后自己新建应用或者一个代码包都是在src目录下新建一个文件夹,文件夹名称一般是代码包名称,当然也允许多级目录。
例如在src下面新建了目录$GOPATH/src/github.com/astaxie/beedb,
那么这个 包路径 就是github.com/astaxie/beedb
,包名称 是最后一个目录beedb
。
执行如下代码
cd $GOPATH/src
mkdir mymath
新建文件sqrt.go,内容如下
// $GOPATH/src/mymath/sqrt.go源码如下:
package mymath
func Sqrt(x float64) float64 {
z := 0.0
for i := 0; i < 1000; i++ {
z -= (z*z - x) / (2 * x)
}
return z
}
这样我的应用包目录和代码已经新建完毕,注意:一般建议package的名称和目录名保持一致。
编译应用
上面我们已经建立了自己的应用包,如何进行编译安装呢?有两种方式可以进行安装
- 只要进入对应的应用包目录,然后执行
go install
,就可以安装了 - 在任意的目录执行如下代码
go install mymath
安装完之后,我们可以进入如下目录
cd $GOPATH/pkg/${GOOS}_${GOARCH}
//可以看到如下文件
mymath.a
这个.a文件是应用包,那么我们如何进行调用呢?
接下来我们新建一个应用程序来调用
新建应用包mathapp
cd $GOPATH/src
mkdir mathapp
cd mathapp
vim main.go
// `$GOPATH/src/mathapp/main.go`源码:
package main
import (
"mymath"
"fmt"
)
func main() {
fmt.Printf("Hello, world. Sqrt(2) = %v\n", mymath.Sqrt(2))
}
如何编译程序呢?进入该应用目录,然后执行go build
,那么在该目录下面会生成一个mathapp的可执行文件
./mathapp
输出如下内容
Hello, world. Sqrt(2) = 1.414213562373095
如何安装该应用?
进入该目录执行go install
,那么在$GOPATH/bin/下增加了一个可执行文件mathapp,这样可以在命令行输入如下命令就可以执行。
mathapp
也是输出如下内容
Hello, world. Sqrt(2) = 1.414213562373095
获取远程包
go语言有一个获取远程包的工具就是go get
,
目前go get支持多数开源社区(例如:github、googlecode、bitbucket、Launchpad)
$ go get github.com/astaxie/beedb
go get -u 参数可以自动更新包,而且当go get的时候会自动获取该包依赖的其他第三方包。
tips
当前使用
go get
时,很大概率会拉到依赖google某些源代码的库,由于众所周知的原因,中国大陆 直接访问会受阻,所以很有可能需要借助梯子才能拉下来。
通过这个命令可以获取相应的源码,对应的开源平台采用不同的源码控制工具, 例如github采用git、googlecode采用hg,所以要想获取这些源码,必须先安装相应的源码控制工具
通过上面获取的代码在我们本地的源码相应的代码结构如下
$GOPATH
src
|--github.com
|-astaxie
|-beedb
pkg
|--相应平台
|-github.com
|--astaxie
|beedb.a
go get
本质上可以理解为首先第一步是通过源码工具clone代码到src下面,然后执行go install
在代码中如何使用远程包?
很简单的就是和使用本地包一样,只要在开头import相应的路径就可以
import "github.com/astaxie/beedb"
程序的整体结构
通过上面建立的我本地的mygo的目录结构如下所示
bin/
mathapp
pkg/
平台名/ 如:darwin_amd64、linux_amd64
mymath.a
github.com/
astaxie/
beedb.a
src/
mathapp
main.go
mymath/
sqrt.go
github.com/
astaxie/
beedb/
beedb.go
util.go
从上面的结构我们可以很清晰的看到:
- bin目录下面存的是编译之后可执行的文件
- pkg下面存放的是函数包
- src下面保存的是应用源代码