增加了第四小节、第五小节,修改了一些错别字
This commit is contained in:
4
1.2.md
4
1.2.md
@@ -97,8 +97,8 @@ GOPATH允许多个目录,当有多个目录时,请注意分隔符,多个go
|
||||
|
||||
Hello, world. Sqrt(2) = 1.414213562373095
|
||||
|
||||
## 获取远程包内容
|
||||
go语言有一个获取原承包的工具就是`go get`,目前go get支持多数开源社区(例如:github、googlecode、bitbucket、Launchpad)
|
||||
## 获取远程包
|
||||
go语言有一个获取远程包的工具就是`go get`,目前go get支持多数开源社区(例如:github、googlecode、bitbucket、Launchpad)
|
||||
|
||||
go get github.com/astaxie/beedb
|
||||
|
||||
|
||||
19
1.3.md
19
1.3.md
@@ -6,16 +6,16 @@
|
||||
|
||||

|
||||
|
||||
这些命令对于我们平时编写的代码非常有用,接下来我将我们平常用到最多的几个命令进行大概的讲解
|
||||
这些命令对于我们平时编写的代码非常有用,接下来我将就平常用到比较多的几个命令进行简要的讲解
|
||||
|
||||
##go build
|
||||
|
||||
这个命令主要是用来编译包的,在包编译过程会同时去编译相应的关联包
|
||||
这个命令主要是用来测试编译的,在包编译过程中,若有必要会同时去编译相应的关联包
|
||||
|
||||
- 如果是pkg包,例如第一章里面写的mymath包,你执行`go build`的时候,不会产生任何的文件,因为他不会默认帮你去安装,如果你需要在pkg下面生成相应的文件,那么就需要执行`go install`
|
||||
- 如果你的程序是main包,那么就会在你的目录下面生成一个可执行文件,这个文件你是可以执行的,但是不会生成文件到bin目录下面
|
||||
- 如果你的程序是main包,那么就会在你的目录下面生成一个可执行文件,但是不会生成文件到bin目录下面
|
||||
|
||||
如果你项目文件下面有好多个文件,又只想指定编译某个文件,这个命令可以指定编译文件,例如`go build a.go`,`go build`命令默认编译目录下全部的go文件
|
||||
如果某个项目文件夹下有多个文件,又只想指定编译某个文件,这个命令可以指定编译文件,例如`go build a.go`,`go build`命令默认编译目录下全部的go文件
|
||||
|
||||
你也可以指定编译输出文件的名称,例如第一章的那个mathapp应用,我可以指定`go build -o astaxie.exe`,默认情况是你的package名,就是你的文件夹名称
|
||||
|
||||
@@ -40,22 +40,22 @@
|
||||
|
||||
##go fmt
|
||||
|
||||
go还有一个优雅的地方就是提供了这个命令,他能够格式化代码,让所有人写的代码能够保持一种风格,这个真是太美妙了,这个命令可以帮你格式化你写好的文件,在你写代码的时候不需要关心格式,写完之后执行以下这个命令,就自动帮你修改成了标准格式,但是我平常很少用到这个命令,因为开发工具里面一般都带了保存的时候自动格式化,其实底层就是调用了这个命令。接下来的一节我将讲述两个工具,这两个工具都自带了保存文件自动化`go fmt`功能。
|
||||
有过c/c++经验的读者会知道,一些人经常为代码采取k&r风格还是 ansi风格而争论不休,在go中,代码有标准风格.由于之前已经有的一些习惯或其他的原因我们常将代码写成ansi风格或者其他更合适自己的格式,这将为人们在阅读别人的代码时添加不必要的负担,所以go强制了代码格式( 比如左大括号必须放在行尾),不按照此格式的代码将不能编译通过,为了减少浪费在排版上的时间,go工具集中提供了一个 go fmt命令 它可以帮你格式化你写好的代码文件,使你写代码的时候不需要关心格式,你只需要在写完之后执行`go fmt 文件名.go`,你的代码就被修改成了标准格式,但是我平常很少用到这个命令,因为开发工具里面一般都带了保存时候自动格式化功能,这个功能其实在底层就是调用了`go fmt`。接下来的一节我将讲述两个工具,这两个工具都自带了保存文件自动化`go fmt`功能。
|
||||
|
||||
##go get
|
||||
|
||||
这个命令是用来动态获取远程代码包的,目前支持的有BitBucket、GitHub、Google Code 、Launchpad ,这个命令也是分成了两步操作,第一步是下载源码包,第二步是`go install`,下载源码包go工具会自动根据不同的域名调用不同的源码工具,对应关系如下:
|
||||
这个命令是用来动态获取远程代码包的,目前支持的有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 get` 能正常工作,你必须确保安装了合适的 源码管理工具同时把这些命令加入你的path
|
||||
|
||||
##go install
|
||||
|
||||
这个命令可以拆分成两个步骤,第一步就是`go build`,然后就是把编译的东西copy到了pkg或者bin
|
||||
这个命令在内部实际上分成了两步操作,第一步就是`go build`,然后就是把编译的东西copy到了pkg或者bin
|
||||
|
||||
##go test
|
||||
|
||||
@@ -75,7 +75,8 @@
|
||||
如何查看相应package的文档呢?
|
||||
例如builtin包,那么执行`go doc builtin`
|
||||
如果是http包,那么执行`go doc net/http`
|
||||
查看某一个包里面的函数,那么执行`godoc fmt Printf`
|
||||
查看某一个包里面的函数,那么执行`godoc fmt Printf`
|
||||
也可以查看相应的代码,执行`godoc -src fmt Printf`
|
||||
|
||||
##其他命令
|
||||
|
||||
|
||||
71
1.4.md
Normal file
71
1.4.md
Normal file
@@ -0,0 +1,71 @@
|
||||
#1.4 GO开发工具
|
||||
|
||||
接下来介绍的两个工具都具有跨平台行,自动化提示,自动化fmt功能,所以介绍的安装步骤之类的都是所有平台通用的。
|
||||
|
||||
##liteide
|
||||
|
||||
liteide这个工具是由我们国内牛人VFC写的,使用起来相当的方便,他支持代码自动提示、项目、项目编译等,[下载地址](http://code.google.com/p/golangide/downloads/list)
|
||||
|
||||
根据自己的系统下载相应的版本,这些都是已经编译好的文件,window和ubuntu系统直接打开bin下面的liteide,mac通过launchpad打开liteide
|
||||
|
||||

|
||||
|
||||
大家可以看到左边是文件项目列表,左下角有相应的文件类导航,顶部有相应的调试工具和编译工具,主要的这个工具支持自动化提示同时支持本文件中函数的提示,目前还没有做到整个项目中函数的提示。配置也是很方便的,只要你已经安装前面几个小节配置了相应的go和gopath,那么打开软件之后,就可以直接新建项目开始用了。
|
||||
|
||||
|
||||
##Sublime text
|
||||
|
||||
这里将介绍sublime text2+gosublime+gocode的组合,那么为什么选择这个组合呢?
|
||||
|
||||
- 自动化提示代码,如下图所示
|
||||

|
||||
|
||||
- 保存的时候自动格式化代码,让您编写的代码更加美观,符合golang的标准
|
||||
- 支持项目管理
|
||||

|
||||
- 支持语法高亮
|
||||
- sublime text2免费,只是保存次数达到一定数量之后就会提示是否购买,点击取消继续用,和正式注册版本没有任何区别
|
||||
|
||||
接下来就开始讲如何安装,下载[sublimetext](http://www.sublimetext.com/)
|
||||
|
||||
根据自己相应的系统下载相应的版本,然后打开sublimetext,对于不熟悉sublimetext的同学可以先看一下这篇文章 [Sublime Text 2 入门及技巧](http://lucifr.com/139225/sublime-text-2-tricks-and-tips/)
|
||||
|
||||
1.打开之后安装 Package Control:ctrl+` 打开命令行,执行如下代码
|
||||
|
||||
import urllib2,os; pf='Package Control.sublime- package';pp=sublime.installed_packages_path(); os.makedirs(ipp) if not os.path.exists(ipp) else
|
||||
None;urllib2.install_opener(urllib2.build_opener(urllib2.ProxyHandler())); open(os.path.join(ipp,pf),'wb').write(urllib2.urlopen('http:// sublime.wbond.net/'+pf.replace(' ','%20')).read()); print 'Please restart Sublime Text to finish installation'
|
||||
|
||||
这个时候你重启一下sublimetext,可以发现在在菜单栏多了一个如下的栏目,说明package control已经安装成功了
|
||||
|
||||

|
||||
|
||||
2.接下来安装gocode https://github.com/nsf/gocode
|
||||
打开终端运行如下代码
|
||||
|
||||
go get -u github.com/nsf/gocode
|
||||
go get -u github.com/DisposaBoy/MarGo
|
||||
|
||||
这个时候我们会发现在gopath/bin下面多了两个可执行文件,gocode和margo,这两个文件会在gosublime起来的时候自动启动
|
||||
|
||||
3.安装完之后就可以安装sublimetext的插件了,安装gosublime、sidebar(增强边栏),安装插件之后记得重启sublimetext生效,ctrl+shift+p打开package controll 输入pcip
|
||||
|
||||
这个时候看左下角显示正在读取包数据,完成之后出现如下界面
|
||||
|
||||

|
||||
|
||||
这个时候输入gosublime,按确定就开始安装了,同理应用于sidebar
|
||||
|
||||
4.验证是否安装成功,你可以打开sublimetext,打开main.go,看看语法是不是高亮了,输入import是不是自动化提示了,import "fmt"之后,输入fmt.是不是自动化提示有函数了
|
||||
|
||||
如果已经出现这个提示,那说明你已经安装完成了,并且完成了自动提示
|
||||
|
||||
如果没有出现这样的提示,一般就是你的path没有配置正确,你可以打开终端,输入gocode,是不是能够正确运行,如果不行就说明path没有配置正确
|
||||
|
||||
|
||||
## links
|
||||
* [目录](<preface.md>)
|
||||
* 上一节: [Go Shell命令](<1.3.md>)
|
||||
* 下一节: [总结](<1.5.md>)
|
||||
|
||||
## LastModified
|
||||
* $Id$
|
||||
11
1.5.md
Normal file
11
1.5.md
Normal file
@@ -0,0 +1,11 @@
|
||||
#总结
|
||||
|
||||
这一章中我们主要介绍了如何安装go,已经如何配置本地的gopath,通过设置gopath之后创建项目,项目如何编译,接着介绍了一些go的常用命令工具,最后介绍了go的开发工具,希望能够通过有利的工具快速的开发go应用
|
||||
|
||||
## links
|
||||
* [目录](<preface.md>)
|
||||
* 上一节: [Go开发工具](<1.4.md>)
|
||||
* 下一章: [go语言基础](<2.md>)
|
||||
|
||||
## LastModified
|
||||
* $Id$
|
||||
BIN
images/1.4.liteide.png
Normal file
BIN
images/1.4.liteide.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 341 KiB |
BIN
images/1.4.sublime1.png
Normal file
BIN
images/1.4.sublime1.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 92 KiB |
BIN
images/1.4.sublime2.png
Normal file
BIN
images/1.4.sublime2.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 55 KiB |
BIN
images/1.4.sublime3.png
Normal file
BIN
images/1.4.sublime3.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 8.4 KiB |
BIN
images/1.4.sublime4.png
Normal file
BIN
images/1.4.sublime4.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 67 KiB |
Reference in New Issue
Block a user