Go語言自帶有一套完整的命令操作工具,你可以通過在命令行中執(zhí)行go
來查看它們:
圖1.3 Go命令顯示詳細的信息
這些命令對于我們平時編寫的代碼非常有用,接下來就讓我們了解一些常用的命令。
這個命令主要用于編譯代碼。在包的編譯過程中,若有必要,會同時編譯與之相關聯(lián)的包。
(注:實際上,package名在Go語言規(guī)范中指代碼中“package”后使用的名稱,此名稱可以與文件夾名不同。默認生成的可執(zhí)行文件名是文件夾名。)
go build的時候會選擇性地編譯以系統(tǒng)名結尾的文件(Linux、Darwin、Windows、Freebsd)。例如Linux系統(tǒng)下面編譯只會選擇array_linux.go文件,其它系統(tǒng)命名后綴文件全部忽略。
參數(shù)的介紹
這個命令是用來移除當前源碼包和關聯(lián)源碼包里面編譯生成的文件。這些文件包括
_obj/ 舊的object目錄,由Makefiles遺留
_test/ 舊的test目錄,由Makefiles遺留
_testmain.go 舊的gotest文件,由Makefiles遺留
test.out 舊的test記錄,由Makefiles遺留
build.out 舊的test記錄,由Makefiles遺留
*.[568ao] object文件,由Makefiles遺留
?
DIR(.exe) 由go build產(chǎn)生
DIR.test(.exe) 由go test -c產(chǎn)生
MAINFILE(.exe) 由go build MAINFILE.go產(chǎn)生
*.so 由 SWIG 產(chǎn)生
我一般都是利用這個命令清除編譯文件,然后GitHub遞交源碼,在本機測試的時候這些編譯文件都是和系統(tǒng)相關的,但是對于源碼管理來說沒必要。
$ go clean -i -n
cd /Users/astaxie/develop/gopath/src/mathapp
rm -f mathapp mathapp.exe mathapp.test mathapp.test.exe app app.exe
rm -f /Users/astaxie/develop/gopath/bin/mathapp
參數(shù)介紹
有過C/C++經(jīng)驗的讀者會知道,一些人經(jīng)常為代碼采取K&R風格還是ANSI風格而爭論不休。在go中,代碼則有標準的風格。由于之前已經(jīng)有的一些習慣或其它的原因我們常將代碼寫成ANSI風格或者其它更合適自己的格式,這將為人們在閱讀別人的代碼時添加不必要的負擔,所以go強制了代碼格式(比如左大括號必須放在行尾),不按照此格式的代碼將不能編譯通過,為了減少浪費在排版上的時間,go工具集中提供了一個go fmt命令 它可以幫你格式化你寫好的代碼文件,使你寫代碼的時候不需要關心格式,你只需要在寫完之后執(zhí)行go fmt <文件名>.go,你的代碼就被修改成了標準格式,但是我平常很少用到這個命令,因為開發(fā)工具里面一般都帶了保存時候自動格式化功能,這個功能其實在底層就是調用了go fmt。接下來的一節(jié)我將講述兩個工具,這兩個工具都自帶了保存文件時自動化go fmt功能。
使用go fmt命令,其實是調用了gofmt,而且需要參數(shù)-w,否則格式化結果不會寫入文件。gofmt -w -l src,可以格式化整個項目。
所以go fmt是gofmt的上層一個包裝的命令,我們想要更多的個性化的格式化可以參考 gofmt
gofmt的參數(shù)介紹
這個命令是用來動態(tài)獲取遠程代碼包的,目前支持的有BitBucket、GitHub、Google Code和Launchpad。這個命令在內部實際上分成了兩步操作:第一步是下載源碼包,第二步是執(zhí)行go install。下載源碼包的go工具會自動根據(jù)不同的域名調用不同的源碼工具,對應關系如下:
BitBucket (Mercurial Git)
GitHub (Git)
Google Code Project Hosting (Git, Mercurial, Subversion)
Launchpad (Bazaar)
所以為了go get 能正常工作,你必須確保安裝了合適的源碼管理工具,并同時把這些命令加入你的PATH中。其實go get支持自定義域名的功能,具體參見go help remote。
參數(shù)介紹:
這個命令在內部實際上分成了兩步操作:第一步是生成結果文件(可執(zhí)行文件或者.a包),第二步會把編譯好的結果移到$GOPATH/pkg或者$GOPATH/bin。
參數(shù)支持go build的編譯參數(shù)。大家只要記住一個參數(shù)-v就好了,這個隨時隨地的可以查看底層的執(zhí)行信息。
執(zhí)行這個命令,會自動讀取源碼目錄下面名為*_test.go的文件,生成并運行測試用的可執(zhí)行文件。輸出的信息類似
ok archive/tar 0.011s
FAIL archive/zip 0.022s
ok compress/gzip 0.033s
...
默認的情況下,不需要任何的參數(shù),它會自動把你源碼包下面所有test文件測試完畢,當然你也可以帶上參數(shù),詳情請參考go help testflag
這里我介紹幾個我們常用的參數(shù):
go tool下面下載聚集了很多命令,這里我們只介紹兩個,fix和vet
這個命令是從Go1.4開始才設計的,用于在編譯前自動化生成某類代碼。go generate和go build是完全不一樣的命令,通過分析源碼中特殊的注釋,然后執(zhí)行相應的命令。這些命令都是很明確的,沒有任何的依賴在里面。而且大家在用這個之前心里面一定要有一個理念,這個go generate是給你用的,不是給使用你這個包的人用的,是方便你來生成一些代碼的。
這里我們來舉一個簡單的例子,例如我們經(jīng)常會使用yacc來生成代碼,那么我們常用這樣的命令:
go tool yacc -o gopher.go -p parser gopher.y
-o 指定了輸出的文件名, -p指定了package的名稱,這是一個單獨的命令,如果我們想讓go generate來觸發(fā)這個命令,那么就可以在當前目錄的任意一個xxx.go文件里面的任意位置增加一行如下的注釋:
//go:generate go tool yacc -o gopher.go -p parser gopher.y
這里我們注意了,//go:generate是沒有任何空格的,這其實就是一個固定的格式,在掃描源碼文件的時候就是根據(jù)這個來判斷的。
所以我們可以通過如下的命令來生成,編譯,測試。如果gopher.y文件有修改,那么就重新執(zhí)行go generate重新生成文件就好。
$ go generate
$ go build
$ go test
在Go1.2版本之前還支持go doc命令,但是之后全部移到了godoc這個命令下,需要這樣安裝go get golang.org/x/tools/cmd/godoc
很多人說go不需要任何的第三方文檔,例如chm手冊之類的(其實我已經(jīng)做了一個了,chm手冊),因為它內部就有一個很強大的文檔工具。
如何查看相應package的文檔呢? 例如builtin包,那么執(zhí)行godoc builtin 如果是http包,那么執(zhí)行godoc net/http 查看某一個包里面的函數(shù),那么執(zhí)行godoc fmt Printf 也可以查看相應的代碼,執(zhí)行godoc -src fmt Printf
通過命令在命令行執(zhí)行 godoc -http=:端口號 比如godoc -http=:8080。然后在瀏覽器中打開127.0.0.1:8080,你將會看到一個golang.org的本地copy版本,通過它你可以查詢pkg文檔等其它內容。如果你設置了GOPATH,在pkg分類下,不但會列出標準包的文檔,還會列出你本地GOPATH中所有項目的相關文檔,這對于經(jīng)常被墻的用戶來說是一個不錯的選擇。
go還提供了其它很多的工具,例如下面的這些工具
go version 查看go當前的版本
go env 查看當前go的環(huán)境變量
go list 列出當前全部安裝的package
go run 編譯并運行Go程序
以上這些工具還有很多參數(shù)沒有一一介紹,用戶可以使用go help 命令獲取更詳細的幫助信息。
更多建議: