C++的代码的组织,依赖的管理规定几乎为零。学习golang的时候,一上来就是看语法,看代码,在代码组织和依赖管理这里碰了不少壁,所以重新看了一下官方文档,并做下备忘。
注意:Go是跨平台的,本文基于Ubuntu(Linux)。
rm /usr/local/go
。/usr/local/go
。$HOME/.profile
文件中加上export PATH=$PATH:/usr/local/go/bin
。go version
。一个Workspace下有三个目录:
src
存放Go源码,包括自己写的代码和import
的第三方代码。pkg
存放包对象——编译后的二进制目标文件。bin
存放可执行文件。GOPATH
就是你的workspace的路径。默认是$HOME/go
。注意:GOPATH
不能与go的安装路径相同。go env GOPATH
:查看当前生效的GOPATH的值。$GOPTH/bin
路径加入到$PATH
export PATH=$PATH:$(go env GOPATH)/bin
假设你的代码的base path是github.com/user
。
mkdir -p $GOPATH/src/github.com/user
。mkdir -p $GOPATH/src/github.com/user/hello
。hello.go
package main
import "fmt"
func main() {
fmt.Println("Hello World")
}
go build github.com/user/hello
在当前路径生成可执行文件。go build
在hello目录下执行(下面go install
go test
都类似)。go install github.com/user/hello
在$GOPATH/bin
目录下生成可执行文件。mkdir -p $GOPATH/src/github.com/user/stringutil
。reverse.go
。package stringutil
func Reverse(s string) string {
r := []rune(s)
for i, j := 0, len(r)-1; i < len(r)/2; i, j = i+1, j-1 {
r[i], r[j] = r[j], r[i]
}
return string(r)
}
go build github.com/user/stringutil
不会生成任何东西,但是如果代码有问题会报错。go install github.com/user/stringutil
在生成二进制目标文件。stringutil.Reverse
package main
import (
"fmt"
"github.com/JinheLin/stringutil"
)
func main() {
fmt.Println(stringutil.Reverse("!oG ,olleH"))
}
go test
命令和package testing
组成。xxx_test.go
:在stringutils下为reverse.go创建一个测试代码文件reverse_test.go。package stringutil
import "testing"
func TestReverse(t *testing.T) {
cases := []struct {
in, want string
}{
{"Hello, world", "dlrow ,olleH"},
{"Hello, 世界", "界世 ,olleH"},
{"", ""},
}
for _, c := range cases {
got := Reverse(c.in)
if got != c.want {
t.Errorf("Reverse(%q) == %q, want %q", c.in, got, c.want)
}
}
}
go test github.com/user/stringutil
。