您好,登錄后才能下訂單哦!
在Go語言中,我們很多操作都是通過go
命令進行的,比如我們要執行go文件的編譯,就需要使用go build
命令,除了build
命令之外,還有很多常用的命令,這一次我們就統一進行介紹,對常用命令有一個了解,這樣我們就可以更容易地開發我們的Go程序了。
Go 開發工具概覽
go
這個工具,別看名字短小,其實非常強大,是一個強大的開發工具,讓我們打開終端,看看這個工具有哪些能力。
~ go Go is a tool for managing Go source code. Usage: go command [arguments] The commands are: build compile packages and dependencies clean remove object files doc show documentation for package or symbol env print Go environment information bug start a bug report fix run go tool fix on packages fmt run gofmt on package sources generate generate Go files by processing source get download and install packages and dependencies install compile and install packages and dependencies list list packages run compile and run Go program test test packages tool run specified go tool version print Go version vet run go tool vet on packages Use "go help [command]" for more information about a command. Additional help topics: c calling between Go and C buildmode description of build modes filetype file types gopath GOPATH environment variable environment environment variables importpath import path syntax packages description of package lists testflag description of testing flags testfunc description of testing functions Use "go help [topic]" for more information about that topic.
可以發現,go支持的子命令很多,同時還支持查看一些【主題】。我們可以使用go help [command]
或者go help [topic]
查看一些命令的使用幫助,或者關于某個主題的信息。大部分go的命令,都是接受一個全路徑的包名作為參數,比如我們經常用的go build
。
go build
go build
,是我們非常常用的命令,它可以啟動編譯,把我們的包和相關的依賴編譯成一個可執行的文件。
usage: go build [-o output] [-i] [build flags] [packages]
go build
的使用比較簡潔,所有的參數都可以忽略,直到只有go build
,這個時候意味著使用當前目錄進行編譯,下面的幾條命令是等價的:
go build go build . go build hello.go
以上這三種寫法,都是使用當前目錄編譯的意思。因為我們忽略了packages
,所以自然就使用當前目錄進行編譯了。從這里我們也可以推測出,go build
本質上需要的是一個路徑,讓編譯器可以找到哪些需要編譯的go文件。packages
其實是一個相對路徑,是相對于我們定義的GOROOT
和GOPATH
這兩個環境變量的,所以有了packages
這個參數后,go build
就可以知道哪些需要編譯的go文件了。
go build flysnow.org/tools
這種方式是指定包的方式,這樣會明確地編譯我們這個包。當然我們也可以使用通配符。
go build flysnow.org/tools/...
3個點表示匹配所有字符串,這樣go build
就會編譯tools目錄下的所有包。
講到go build
編譯,不能不提跨平臺編譯,Go提供了編譯鏈工具,可以讓我們在任何一個開發平臺上,編譯出其他平臺的可執行文件。
默認情況下,都是根據我們當前的機器生成的可執行文件,比如你的是Linux 64位,就會生成Linux 64位下的可執行文件,比如我的Mac;可以使用go env查看編譯環境,以下截取重要的部分。
~ go env GOARCH="amd64" GOEXE="" GOHOSTARCH="amd64" GOHOSTOS="darwin" GOOS="darwin" GOROOT="/usr/local/go" GOTOOLDIR="/usr/local/go/pkg/tool/darwin_amd64"
注意里面兩個重要的環境變量GOOS和GOARCH,其中GOOS指的是目標操作系統,它的可用值為:
darwin
freebsd
linux
windows
android
dragonfly
netbsd
openbsd
plan9
solaris
一共支持10種操作系統。GOARCH指的是目標處理器的架構,目前支持的有:
arm
arm64
386
amd64
ppc64
ppc64le
mips64
mips64le
s390x
一共支持9種處理器的架構,GOOS和GOARCH組合起來,支持生成的可執行程序種類很多,具體組合參考:
https://golang.org/doc/install/source#environment
如果我們要生成不同平臺架構的可執行程序,只要改變這兩個環境變量就可以了,比如要生成Linux 64位的程序,命令如下:
GOOS=linux GOARCH=amd64 go build flysnow.org/hello
前面兩個賦值,是更改環境變量,這樣的好處是只針對本次運行有效,不會更改我們默認的配置。
以上這些用法差不多夠我們用的了,更多關于go build
的用戶可以通過以下命令查看:
go help build
go clean
在我們使用go build
編譯的時候,會產生編譯生成的文件,尤其是在我們簽入代碼的時候,并不想把我們生成的文件也簽入到我們的Git代碼庫中,這時候我們可以手動刪除生成的文件,但是有時候會忘記,也很麻煩,不小心還是會提交到Git中。要解決這個問題,我們可以使用go clean
,它可以清理我們編譯生成的文件,比如生成的可執行文件,生成obj對象等。
usage: go clean [-i] [-r] [-n] [-x] [build flags] [packages]
用法和go build
基本一樣,這樣不再進行詳細舉例演示,可以參考go build
的使用,更多關于go clean
的使用,可以使用如下命令查看:
go help clean
go run
go build
是先編譯,然后我們再執行可以執行文件來運行我們的程序,需要兩步。go run
這個命令就是可以把這兩步合成一步的命令,節省了我們錄入的時間,通過go run
命令,我們可以直接看到輸出的結果。
~ go help run usage: go run [build flags] [-exec xprog] gofiles... [arguments...] Run compiles and runs the main package comprising the named Go source files. A Go source file is defined to be a file ending in a literal ".go" suffix. By default, 'go run' runs the compiled binary directly: 'a.out arguments...'. If the -exec flag is given, 'go run' invokes the binary using xprog: 'xprog a.out arguments...'. If the -exec flag is not given, GOOS or GOARCH is different from the system default, and a program named go_$GOOS_$GOARCH_exec can be found on the current search path, 'go run' invokes the binary using that program, for example 'go_nacl_386_exec a.out arguments...'. This allows execution of cross-compiled programs when a simulator or other execution method is available. For more about build flags, see 'go help build'.
go run
命令需要一個go文件作為參數,這個go文件必須包含main包和main函數,這樣才可以運行,其他的參數和go build
差不多。 在運行go run
的時候,如果需要的話,我們可以給我們的程序傳遞參數,比如:
package main import ( "fmt" "os" ) func main() { fmt.Println("輸入的參數為:",os.Args[1]) }
打開終端,輸入如下命令執行:
go run main.go 12
這時候我們就可以看到輸出:
輸入的參數為: 12
go env
在前面講go build
的時候,我們使用了go env
命令查看了我們當前的go環境信息。
hello go help env usage: go env [var ...] Env prints Go environment information. By default env prints information as a shell script (on Windows, a batch file). If one or more variable names is given as arguments, env prints the value of each named variable on its own line.
使用go env
查看我們的go環境信息,便于我們進行調試,排錯等,因為有時候我們會遇到一些莫名其妙的問題,比如本來在Mac上開發,怎么編譯出一個Linux的可執行文件等,遇到這類問題時,先查看我們的go環境信息,看看有沒有哪里配置錯了,一步步排錯。
go install
從其名字上我們不難猜出這個命令是做什么的,它和go build
類似,不過它可以在編譯后,把生成的可執行文件或者庫安裝到對應的目錄下,以供使用。
hello go help install usage: go install [build flags] [packages] Install compiles and installs the packages named by the import paths, along with their dependencies.
它的用法和go build
差不多,如果不指定一個包名,就使用當前目錄。安裝的目錄都是約定好的,如果生成的是可執行文件,那么安裝在$GOPATH/bin
目錄下;如果是可引用的庫,那么安裝在$GOPATH/pkg
目錄下。
go get
go get
命令,可以從網上下載更新指定的包以及依賴的包,并對它們進行編譯和安裝。
go get github.com/spf13/cobra
以上示例,我們就可以從github上直接下載這個go庫到我們GOPATH
工作空間中,以供我們使用。下載的是整個源代碼工程,并且會根據它們編譯和安裝,和執行go install
類似。
go get
支持大多數版本控制系統(VCS),比如我們常用的git,通過它和包依賴管理結合,我們可以在代碼中直接導入網絡上的包以供我們使用。
如果我們需要更新網絡上的一個go工程,加-u
標記即可。
go get -u github.com/spf13/cobra
類似的,啟用-v
標記,可以看到下載的進度以及更多的調試信息。關于go get
命令的更多用法,可以使用如下命令查看:
go help get
go fmt
這是go提供的最帥的一個命令了,它可以格式化我們的源代碼的布局和Go源代碼一樣的風格,也就是統一代碼風格,這樣我們再也不用為大括號要不要放到行尾還是另起一行,縮進是使用空格還是tab而爭論不休了,都給我們統一了。
func main() { fmt.Println("輸入的參數為:", os.Args[1]) }
比如以上代碼,我們執行go fmt
格式化后,會變成如下這樣:
func main() { fmt.Println("輸入的參數為:", os.Args[1]) }
go fmt
也是接受一個包名作為參數,如果不傳遞,則使用當前目錄。go fmt
會自動格式化代碼文件并保存,它本質上其實是調用的gofmt -l -w
這個命令,我們看下gofmt
的使用幫助。
hello gofmt -h usage: gofmt [flags] [path ...] -cpuprofile string write cpu profile to this file -d display diffs instead of rewriting files -e report all errors (not just the first 10 on different lines) -l list files whose formatting differs from gofmt's -r string rewrite rule (e.g., 'a[b:len(a)] -> a[b:]') -s simplify code -w write result to (source) file instead of stdout
go fmt
為我們統一了代碼風格,這樣我們在整個團隊協作中發現,所有代碼都是統一的,像一個人寫的一樣。所以我們的代碼在提交到git庫之前,一定要使用go fmt
進行格式化,現在有很多編輯器可以在保存的時候,自動幫我們格式化代碼。
go vet
這個命令不會幫助開發人員寫代碼,但是它也很有用,因為它會幫助我們檢查我們代碼中常見的錯誤。
Printf這類的函數調用時,類型匹配了錯誤的參數。
定義常用的方法時,方法簽名錯誤。
錯誤的結構標簽。
沒有指定字段名的結構字面量。
package main import ( "fmt" ) func main() { fmt.Printf(" 哈哈",3.14) }
這個例子是一個明顯錯誤的例子,新手經常會犯,這里我們忘記輸入了格式化的指令符,這種編輯器是檢查不出來的,但是如果我們使用go vet
就可以幫我們檢查出這類常見的小錯誤。
hello go vet main.go:8: no formatting directive in Printf call
看,提示多明顯。其使用方式和go fmt
一樣,也是接受一個包名作為參數。
usage: go vet [-n] [-x] [build flags] [packages]
養成在代碼提交或者測試前,使用go vet
檢查代碼的好習慣,可以避免一些常見問題。
go test
該命令用于Go的單元測試,它也是接受一個包名作為參數,如果沒有指定,使用當前目錄。 go test
運行的單元測試必須符合go的測試要求。
寫有單元測試的文件名,必須以_test.go
結尾。
測試文件要包含若干個測試函數。
這些測試函數要以Test為前綴,還要接收一個*testing.T
類型的參數。
package main import "testing" func TestAdd(t *testing.T) { if Add(1,2) == 3 { t.Log("1+2=3") } if Add(1,1) == 3 { t.Error("1+1=3") } }
這是一個單元測試,保存在main_test.go
文件中,對main包里的Add(a,b int)
函數進行單元測試。 如果要運行這個單元測試,在該文件目錄下,執行go test
即可。
hello go test PASS ok flysnow.org/hello 0.006s
以上是打印輸出,測試通過。更多關于go test
命令的使用,請通過如下命令查看。
go help test
以上這些,主要介紹的是go這個開發工具常用的命令,熟悉了之后可以幫助我們更好地開發編碼。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。