# 1.2 GOPATH與工作空間
前面我們在安裝Go的時候看到需要設置GOPATH變量,Go從1.1版本開始必須設置這個變量,而且不能和Go的安裝目錄一樣,這個目錄用來存放Go源碼,Go的可運行文件,以及相應的編譯之后的包文件。所以這個目錄下面有三個子目錄:src、bin、pkg
## GOPATH設置
go 命令依賴一個重要的環境變量:$GOPATH
Windows系統中環境變量的形式為`%GOPATH%`,本書主要使用Unix形式,Windows用戶請自行替換。
*(注:這個不是Go安裝目錄。下面以筆者的工作目錄為示例,如果你想不一樣請把GOPATH替換成你的工作目錄。)*
在類似 Unix 環境大概這樣設置:
```sh
export GOPATH=/home/apple/mygo
```
為了方便,應該新建以上文件夾,并且上一行加入到 `.bashrc` 或者 `.zshrc` 或者自己的 `sh` 的配置文件中。
Windows 設置如下,新建一個環境變量名稱叫做GOPATH:
```sh
GOPATH=c:\mygo
```
GOPATH允許多個目錄,當有多個目錄時,請注意分隔符,多個目錄的時候Windows是分號,Linux系統是冒號,當有多個GOPATH時,默認會將go get的內容放在第一個目錄下。
以上 $GOPATH 目錄約定有三個子目錄:
- src 存放源代碼(比如:.go .c .h .s等)
- pkg 編譯后生成的文件(比如:.a)
- bin 編譯后生成的可執行文件(為了方便,可以把此目錄加入到 $PATH 變量中,如果有多個gopath,那么使用`${GOPATH//://bin:}/bin`添加所有的bin目錄)
以后我所有的例子都是以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
下面我就以mymath為例來講述如何編寫應用包,執行如下代碼
```sh
cd $GOPATH/src
mkdir mymath
```
新建文件sqrt.go,內容如下
```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的名稱和目錄名保持一致
## 編譯應用
上面我們已經建立了自己的應用包,如何進行編譯安裝呢?有兩種方式可以進行安裝
1、只要進入對應的應用包目錄,然后執行`go install`,就可以安裝了
2、在任意的目錄執行如下代碼`go install mymath`
安裝完之后,我們可以進入如下目錄
```sh
cd $GOPATH/pkg/${GOOS}_${GOARCH}
//可以看到如下文件
mymath.a
```
這個.a文件是應用包,那么我們如何進行調用呢?
接下來我們新建一個應用程序來調用這個應用包
新建應用包mathapp
```sh
cd $GOPATH/src
mkdir mathapp
cd mathapp
vim main.go
```
`$GOPATH/src/mathapp/main.go`源碼:
```go
package main
import (
"mymath"
"fmt"
)
func main() {
fmt.Printf("Hello, world. Sqrt(2) = %v\n", mymath.Sqrt(2))
}
```
可以看到這個的package是`main`,import里面調用的包是`mymath`,這個就是相對于`$GOPATH/src`的路徑,如果是多級目錄,就在import里面引入多級目錄,如果你有多個GOPATH,也是一樣,Go會自動在多個`$GOPATH/src`中尋找。
如何編譯程序呢?進入該應用目錄,然后執行`go build`,那么在該目錄下面會生成一個mathapp的可執行文件
```sh
./mathapp
```
輸出如下內容
```sh
Hello, world. Sqrt(2) = 1.414213562373095
```
如何安裝該應用,進入該目錄執行`go install`,那么在$GOPATH/bin/下增加了一個可執行文件mathapp, 還記得前面我們把`$GOPATH/bin`加到我們的PATH里面了,這樣可以在命令行輸入如下命令就可以執行
```sh
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的時候會自動獲取該包依賴的其他第三方包
通過這個命令可以獲取相應的源碼,對應的開源平臺采用不同的源碼控制工具,例如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下面保存的是應用源代碼
## links
* [目錄](<preface.md>)
* 上一節: [GO安裝](<01.1.md>)
* 下一節: [GO 命令](<01.3.md>)
- 目錄
- Go環境配置
- Go安裝
- GOPATH 與工作空間
- Go 命令
- Go開發工具
- 小結
- Go語言基礎
- 你好,Go
- Go基礎
- 流程和函數
- struct
- 面向對象
- interface
- 并發
- 小結
- Web基礎
- web工作方式
- Go搭建一個簡單的web服務
- Go如何使得web工作
- Go的http包詳解
- 小結
- 表單
- 處理表單的輸入
- 驗證表單的輸入
- 預防跨站腳本
- 防止多次遞交表單
- 處理文件上傳
- 小結
- 訪問數據庫
- database/sql接口
- 使用MySQL數據庫
- 使用SQLite數據庫
- 使用PostgreSQL數據庫
- 使用beedb庫進行ORM開發
- NOSQL數據庫操作
- 小結
- session和數據存儲
- session和cookie
- Go如何使用session
- session存儲
- 預防session劫持
- 小結
- 文本文件處理
- XML處理
- JSON處理
- 正則處理
- 模板處理
- 文件操作
- 字符串處理
- 小結
- Web服務
- Socket編程
- WebSocket
- REST
- RPC
- 小結
- 安全與加密
- 預防CSRF攻擊
- 確保輸入過濾
- 避免XSS攻擊
- 避免SQL注入
- 存儲密碼
- 加密和解密數據
- 小結
- 國際化和本地化
- 設置默認地區
- 本地化資源
- 國際化站點
- 小結
- 錯誤處理,調試和測試
- 錯誤處理
- 使用GDB調試
- Go怎么寫測試用例
- 小結
- 部署與維護
- 應用日志
- 網站錯誤處理
- 應用部署
- 備份和恢復
- 小結
- 如何設計一個Web框架
- 項目規劃
- 自定義路由器設計
- controller設計
- 日志和配置設計
- 實現博客的增刪改
- 小結
- 擴展Web框架
- 靜態文件支持
- Session支持
- 表單支持
- 用戶認證
- 多語言支持
- pprof支持
- 小結
- 參考資料