Go学习初步总结
一、安装模块
1.下载资源:https://github.com/golang/go
2.工作完成的支持:
(1)工作空间:go语言代码必须放在工作空间中,其包含三个子目录,菲分别是:
src、bin、pkg其中src放源码,bin放可执行文件,pkg放执行包,如下图所示:
bin/
streak # 可执行命令
todo # 可执行命令
pkg/
linux_amd64/
code.google.com/p/goauth2/
oauth.a # 包对象
github.com/nf/todo/
task.a # 包对象
src/
code.google.com/p/goauth2/
.hg/ # mercurial 代码库元数据
oauth/
oauth.go # 包源码
oauth_test.go # 测试源码
github.com/nf/
streak/
.git/ # git 代码库元数据
oauth.go # 命令源码
streak.go # 命令源码
todo/
.git/ # git 代码库元数据
task/
task.go # 包源码
todo.go # 命令源码
(注意:使用goland可以在配置运行的时候配置哪个放在哪儿,库应该会帮忙自动管理这些东西)
(2)GOPAHT变量的设置:主要是指定工作空间的位置, 工作空间下面的文件都可以运行?(大概是这个样子)作为约定,将工作空间的bin子目录添加到PATH中:
$ mkdir $HOME/work
$ export GOPATH=$HOME/work
$ export PATH=$PATH:$GOPATH/bin
(3)包路径:创建一个你放源码的路径
$ mkdir -p $GOPATH/src/github.com/user
二、程序示范
1.创建第一个程序,首先在工作空间创建相应的包目录
$ mkdir $GOPATH/src/github.com/user/hello
而后创建hello.go文件,并且完成代码撰写:
package main
import "fmt"
func main() {
fmt.Printf("Hello, world.\n")
}
将此程序编译:
$ go install github.com/user/hello
注意,你可以在系统的任何地方运行此命令。go 工具会根据 GOPATH 指定的工作空间,在 github.com/user/hello 包内查找源码。
若在从包目录中运行 go install,也可以省略包路径:
$ cd $GOPATH/src/github.com/user/hello
$ go install
此命令会构建 hello 命令,产生一个可执行的二进制文件。 接着它会将该二进制文件作为 hello(在 Windows 下则为 hello.exe)安装到工作空间的 bin 目录中。 在我们的例子中为 $GOPATH/bin/hello,具体一点就是 $HOME/go/bin/hello。
go 工具只有在发生错误时才会打印输出,因此若这些命令没有产生输出, 就表明执行成功了。
现在,你可以在命令行下输入它的完整路径来运行它了:
$ $GOPATH/bin/hello
Hello, world.
若你已经将 $GOPATH/bin 添加到 PATH 中了,只需输入该二进制文件名即可:
$ hello
Hello, world.
三、创建第一个库
1.选择包路径创建包目录:
$ mkdir $GOPATH/src/github.com/user/stringutil
2.编写go文件
// stringutil 包含有用于处理字符串的工具函数。
package stringutil
// Reverse 将其实参字符串以符文为单位左右反转。
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)
}
3.使用go build来编译
$ go build github.com/user/stringutil
4.想要输出的话,必须使用 go install 命令,它会将包的对象放到工作空间的 pkg 目录中。
确认 stringutil 包构建完毕后,修改原来的 hello.go 文件(它位于 $GOPATH/src/github.com/user/hello)去使用它:
package main
import (
"fmt"
"github.com/user/stringutil"
)
func main() {
fmt.Printf(stringutil.Reverse("!oG ,olleH"))
}
来安装 hello 程序时,stringutil 包也会被自动安装。
运行此程序的新版本,你应该能看到一条新的,反向的信息:
$ hello
Hello, Go!
做完上面这些步骤后,你的工作空间应该是这样的:
bin/
hello # 可执行命令
pkg/
linux_amd64/ # 这里会反映出你的操作系统和架构
github.com/user/
stringutil.a # 包对象
src/
github.com/user/
hello/
hello.go # 命令源码
stringutil/
reverse.go # 包源码
四、测试模块
1.Go拥有一个轻量级的测试框架,它由 go test 命令和 testing 包构成。
你可以通过创建一个名字以 _test.go 结尾的,包含名为 TestXXX 且签名为 func (t *testing.T) 函数的文件来编写测试。 测试框架会运行每一个这样的函数;若该函数调用了像 t.Error 或 t.Fail 这样表示失败的函数,此测试即表示失败。
我们可通过创建文件 $GOPATH/src/github.com/user/stringutil/reverse_test.go 来为 stringutil 添加测试,其内容如下:
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 运行该测试:
$ go test github.com/user/stringutil
ok github.com/user/stringutil 0.165s
同样,若你在包目录下运行 go 工具,也可以忽略包路径
$ go test
ok github.com/user/stringutil 0.165s
五、远程包
像Git或Mercurial这样的版本控制系统,可根据导入路径的描述来获取包源代码。go 工具可通过此特性来从远程代码库自动获取包。例如,本文档中描述的例子也可存放到Google Code上的Mercurial仓库 code.google.com/p/go.example 中,若你在包的导入路径中包含了代码仓库的URL,go get 就会自动地获取、 构建并安装它:
$ go get github.com/golang/example/hello
$ $GOPATH/bin/hello
Hello, Go examples!
若指定的包不在工作空间中,go get 就会将会将它放到 GOPATH 指定的第一个工作空间内。(若该包已存在,go get 就会跳过远程获取, 其行为与 go install 相同)
在执行完上面的go get 命令后,工作空间的目录树看起来应该是这样的:
bin/
hello # 可执行命令
pkg/
linux_amd64/
code.google.com/p/go.example/
stringutil.a # 包对象
github.com/user/
stringutil.a # 包对象
src/
code.google.com/p/go.example/
hello/
hello.go # 命令源码
stringutil/
reverse.go # 包源码
reverse_test.go # 测试源码
github.com/user/
hello/
hello.go # 命令源码
stringutil/
reverse.go # 包源码
reverse_test.go # 测试源码