增加第三章关于go命令的说明
This commit is contained in:
93
1.3.md
Normal file
93
1.3.md
Normal file
@@ -0,0 +1,93 @@
|
||||
# 1.3 GO Shell 命令
|
||||
|
||||
##GO 命令
|
||||
|
||||
go语言自带有一套完整的命令操作工具,你可以在你的命令行下面输入`go`,就会出现如下的一些信息
|
||||
|
||||

|
||||
|
||||
这些命令对于我们平时编写的代码非常有用,接下来我将我们平常用到最多的几个命令进行大概的讲解
|
||||
|
||||
##go build
|
||||
|
||||
这个命令主要是用来编译包的,在包编译过程会同时去编译相应的关联包
|
||||
|
||||
- 如果是pkg包,例如第一章里面写的mymath包,你执行`go build`的时候,不会产生任何的文件,因为他不会默认帮你去安装,如果你需要在pkg下面生成相应的文件,那么就需要执行`go install`
|
||||
- 如果你的程序是main包,那么就会在你的目录下面生成一个可执行文件,这个文件你是可以执行的,但是不会生成文件到bin目录下面
|
||||
|
||||
如果你项目文件下面有好多个文件,又只想指定编译某个文件,这个命令可以指定编译文件,例如`go build a.go`,`go build`命令默认编译目录下全部的go文件
|
||||
|
||||
你也可以指定编译输出文件的名称,例如第一章的那个mathapp应用,我可以指定`go build -o astaxie.exe`,默认情况是你的package名,就是你的文件夹名称
|
||||
|
||||
##go clean
|
||||
|
||||
这个命令是用来移除当前源码包里面编译的文件的,这些文件包括
|
||||
|
||||
_obj/ old object directory, left from Makefiles
|
||||
_test/ old test directory, left from Makefiles
|
||||
_testmain.go old gotest file, left from Makefiles
|
||||
test.out old test log, left from Makefiles
|
||||
build.out old test log, left from Makefiles
|
||||
*.[568ao] object files, left from Makefiles
|
||||
|
||||
DIR(.exe) from go build
|
||||
DIR.test(.exe) from go test -c
|
||||
MAINFILE(.exe) from go build MAINFILE.go
|
||||
|
||||
我一般都是利用这个命令进行清除编译文件,然后github递交源码,在本机测试的时候这些编译文件都是和系统相关的,但是对于源码管理来说没必要
|
||||
|
||||
##go fmt
|
||||
|
||||
go还有一个优雅的地方就是提供了这个命令,他能够格式化代码,让所有人写的代码能够保持一种风格,这个真是太美妙了,这个命令可以帮你格式化你写好的文件,在你写代码的时候不需要关心格式,写完之后执行以下这个命令,就自动帮你修改成了标准格式,但是我平常很少用到这个命令,因为开发工具里面一般都带了保存的时候自动格式化,其实底层就是调用了这个命令。接下来的一节我将结束两个工具,这两个工具都自带了保存文件自动化`go fmt`功能。
|
||||
|
||||
##go get
|
||||
|
||||
这个命令是用来动态获取远程代码包的,目前支持的有BitBucket、GitHub、Google Code 、Launchpad ,这个命令也是分成了两步操作,第一步是下载源码包,第二步是`go install`,下载源码包go工具会自动根据不同的域名调用不同的源码工具,对应关系如下:
|
||||
|
||||
BitBucket (Mercurial)
|
||||
GitHub (Git)
|
||||
Google Code Project Hosting (Git, Mercurial, Subversion)
|
||||
Launchpad (Bazaar)
|
||||
|
||||
所以如果你要使用`go get`之前必须安装这些源码管理工具,同时把这些命令加入你的path
|
||||
|
||||
##go install
|
||||
|
||||
这个命令可以拆分成两个步骤,第一步就是`go build`,然后就是把编译的东西copy到了pkg或者bin
|
||||
|
||||
##go test
|
||||
|
||||
执行这个命令,会自动执行源码目录下面命名为`*_test.go`的文件,输入的信息类似
|
||||
|
||||
ok archive/tar 0.011s
|
||||
FAIL archive/zip 0.022s
|
||||
ok compress/gzip 0.033s
|
||||
...
|
||||
|
||||
默认的情况下,不需要任何的参数,他会自动把你源码包下面所有test文件测试完毕,当然你也可以带上参数,详细的参考`go help testflag`
|
||||
|
||||
##go doc
|
||||
|
||||
很多人说go不需要任何的第三方文档,例如chm手册之类的(其实我已经做了一个了,[chm手册](https://github.com/astaxie/godoc) ),因为他内部就有一个很强大的文档工具
|
||||
|
||||
如何查看相应package的文档呢?
|
||||
例如builtin包,那么执行`go doc builtin`
|
||||
如果是http包,那么执行`go doc net/http`
|
||||
|
||||
##其他命令
|
||||
|
||||
go还提供了其他很多的工具,例如下面的这些工具
|
||||
|
||||
go fix 用来修复以前老版本的代码到新版本,例如go1之前老版本的代码转化到go1
|
||||
go version 查看go当前的版本
|
||||
go env 查看当前go的环境变量
|
||||
go list 列出当前全部安装的package
|
||||
go run 编译当前包并执行可执行文件
|
||||
|
||||
## links
|
||||
* [目录](<preface.md>)
|
||||
* 上一节: [GOPATH与工作空间](<1.2.md>)
|
||||
* 下一节: [GO开发工具](<1.4.md>)
|
||||
|
||||
## LastModified
|
||||
* $Id$
|
||||
BIN
images/1.3.go.png
Normal file
BIN
images/1.3.go.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 14 KiB |
30
preface.md
30
preface.md
@@ -1,8 +1,8 @@
|
||||
* 1.GO环境配置
|
||||
- 1.1. GO安装
|
||||
- 1.2. GOPATH 与工作空间
|
||||
- 1.3. GO shell命令
|
||||
- 1.4 第三方包的安装和使用
|
||||
* 1.GO环境配置
|
||||
- 1.1. GO安装
|
||||
- 1.2. GOPATH 与工作空间
|
||||
- 1.3. GO shell命令
|
||||
- 1.4. GO开发工具
|
||||
- 1.5. 小结
|
||||
* 2.编写第一个Web程序
|
||||
- 2.1 概览
|
||||
@@ -12,15 +12,15 @@
|
||||
- 2.5. 编译测试
|
||||
- 2.6. 总结
|
||||
* 3.GO数据类型
|
||||
- 3.1 基础类型
|
||||
- 3.2 string类型
|
||||
- 3.3 数组类型
|
||||
- 3.4 slice类型
|
||||
- 3.5 map类型
|
||||
- 3.6 inteface
|
||||
- 3.7 struct类型
|
||||
- 3.8 面向对象
|
||||
- 3.9 小结
|
||||
- 3.1. 基础类型
|
||||
- 3.2. string类型
|
||||
- 3.3. 数组类型
|
||||
- 3.4. slice类型
|
||||
- 3.5. map类型
|
||||
- 3.6. inteface
|
||||
- 3.7. struct类型
|
||||
- 3.8. 面向对象
|
||||
- 3.9. 小结
|
||||
* 4.正则表达式
|
||||
* 5.web语言处理
|
||||
- 5.1.HTML处理
|
||||
@@ -35,4 +35,4 @@
|
||||
* 12.静态文件服务
|
||||
* 13.如何国际化
|
||||
* 14.编写一个web应用
|
||||
* 15.如何编写测试代码
|
||||
* 15.如何编写测试代码
|
||||
|
||||
Reference in New Issue
Block a user