Go入门:创建第一个Go工程
<div><div>
<h1>前言</h1>
<p>我是一名iOS开发.<br>
因为公司后台都用的Go.</p>
<p>因为对服务端不了解.<br>
所以想自己学习学习.</p>
<h1>环境</h1>
<p>因为自己的电脑是mac.然后在阿里云买的是centOS的服务器.<br>
所以下面搭建的环境都是在centOS系统和MacOS系统下的.</p>
<h1>一.学习资料</h1>
<p>慕课网Go视频教程<br>
GitHub实战教程19000星<br>
beego教程<br>
go视频教程</p>
<h1>二.安装</h1>
<h4>1.1.安装包安装</h4>
<p>Go官网下载安装包<br>
如下图.一直点继续即可.</p>
<div class="image-package">
<div class="image-container" style="max-width: 620px; max-height: 434px">
<div class="image-view" data-width="620" data-height="434"><img src="//upload-images.jianshu.io/upload_images/1452166-68e49f64d3750ac7.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/620"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>安装完成后在终端查看是否安装成功</p>
<div class="image-package">
<div class="image-container" style="max-width: 234px; max-height: 33px">
<div class="image-view" data-width="234" data-height="33"><img src="//upload-images.jianshu.io/upload_images/1452166-7573cf477bbe4b9f.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/234"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<h4>1.2.CentOS下用yum安装</h4>
<p>// 开始安装<br>
$ sudo yum install golang</p>
<p>// 验证是否安装成功<br>
$ go version</p>
<h4>1.3.MacOS下brew安装</h4>
<p>// 开始安装<br>
$ brew install go</p>
<p>// 验证是否成功<br>
$ go env</p>
<h1>二.创建第一个GO工程</h1>
<p>官方创建第一个程序的视频</p>
<div class="image-package">
<div class="image-container" style="max-width: 700px; max-height: 86px">
<div class="image-view" data-width="808" data-height="86"><img src="//upload-images.jianshu.io/upload_images/1452166-edc529de2e035961.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/808"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>1.创建工程的文件夹GXGo</p>
<p>2.在GXGo文件夹里创建src/pkg/bin三个文件夹</p>
<p>3.在src里创建hello文件夹</p>
<p>4.在hello文件夹里创建main工程类<br>
代码如下</p>
<div class="image-package">
<div class="image-container" style="max-width: 289px; max-height: 138px">
<div class="image-view" data-width="289" data-height="138"><img src="//upload-images.jianshu.io/upload_images/1452166-d87a7d4b17a08046.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/289"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>5.设置GOPATH</p>
<blockquote>
<p>export GOPATH=~/Desktop/GXGo</p>
</blockquote>
<p>查看是否设置成功</p>
<div class="image-package">
<div class="image-container" style="max-width: 522px; max-height: 31px">
<div class="image-view" data-width="522" data-height="31"><img src="//upload-images.jianshu.io/upload_images/1452166-c3a7564780967f8b.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/522"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>6.cd到hello文件夹路径下.运行install命令</p>
<div class="image-package">
<div class="image-container" style="max-width: 256px; max-height: 33px">
<div class="image-view" data-width="256" data-height="33"><img src="//upload-images.jianshu.io/upload_images/1452166-97f2bc7df4d1ecda.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/256"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>7.此时go就把hello类编译成了可执行文件.<br>
放在了GXGo/bin路径下<br>
cd到GXGo/bin路径下</p>
<div class="image-package">
<div class="image-container" style="max-width: 610px; max-height: 76px">
<div class="image-view" data-width="610" data-height="76"><img src="//upload-images.jianshu.io/upload_images/1452166-9285a6e66cb9e098.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/610"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>8.运行hello包</p>
<div class="image-package">
<div class="image-container" style="max-width: 201px; max-height: 32px">
<div class="image-view" data-width="201" data-height="32"><img src="//upload-images.jianshu.io/upload_images/1452166-9110230da0332c84.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/201"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>大功告成.你的第一个go项目跑起来了.</p>
<blockquote>
<p>问题一.为什么要创建这三个文件夹呢.<br>
因为GO规定的.<br>
GO规定如下:<br>
src: 存放源代码(.go .c .h .s等)<br>
pkg: 编译后生成的文件 (如: .a)<br>
bin: 编译后生成的可执行文件(为了方便.可以把此目录加入到$PATH变量中.如果有多个GOPATH,那么使用${GOPATH//://bin:}/bin添加所有的bin目录)</p>
</blockquote>
<h1>三.环境变量解释</h1>
<div class="image-package">
<div class="image-container" style="max-width: 700px; max-height: 476px">
<div class="image-view" data-width="729" data-height="476"><img src="//upload-images.jianshu.io/upload_images/1452166-165f6da09781948c.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/729"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>Go安装完成后.<br>
他会提示你需要设置GOPATH和PATH两个变量.</p>
<h3>GOPATH</h3>
<p>指的是你的go项目文件夹路径如: ~/Desktop/GXGo<br>
设置这个是为了能找到你项目文件路径下的src/bin/pkg三个文件夹(这三个文件是需要你手动创建的.也是必须创建的)<br>
这样你运行go install的时候.go就会把编译好的包放进GXGo/bin文件夹里.</p>
<h3>PATH</h3>
<p>PATH是linux自带的一个变量.他相当于给某个文件夹A设置成快捷路径.<br>
你在任何路径下都可以直接访问文件夹A里的脚本.<br>
你可以用终端打印一下PATH已经设置了哪些路径.如下.</p>
<div class="image-package">
<div class="image-container" style="max-width: 307px; max-height: 31px">
<div class="image-view" data-width="307" data-height="31"><img src="//upload-images.jianshu.io/upload_images/1452166-e597a327e3869f15.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/307"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>当我们运行了go install后.<br>
编译好的包就存放在GXGo/bin路径下.<br>
如果想运行这个包.<br>
就需要cd到这个路径下.<br>
然后才能运行这个包.</p>
<p>这样太麻烦了.<br>
我们可以给PATH变量再添加一个快捷路径.如下<br>
export PATH=$PATH:~/Desktop/GXGo/bin</p>
<p>此时你再echo $PATH 就发现你刚才添加的路径已经在里面了.如下</p>
<div class="image-package">
<div class="image-container" style="max-width: 548px; max-height: 30px">
<div class="image-view" data-width="548" data-height="30"><img src="//upload-images.jianshu.io/upload_images/1452166-d067c5a7322d12a8.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/548"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>这样我们就可以在任何路径下都能运行GXGo/bin文件夹里的包了.<br>
就不用如上跑到GXGo/bin下运行包文件了.</p>
<h3>GOROOT</h3>
<p>即你go包安装的根路径<br>
一般是go自动设置好的.你可以使用go env查看一下.<br>
如下GOROOT为/usr/local/Cellar/go/1.9.2/libexec<br>
我们可以去这个路径下查看是否有这个文件.如果有.那就表示不需要我们设置了<br>
如果没有.那就需要export GOROOT=<此处应为go的安装根路径></p>
<div class="image-package">
<div class="image-container" style="max-width: 310px; max-height: 144px">
<div class="image-view" data-width="310" data-height="144"><img src="//upload-images.jianshu.io/upload_images/1452166-d75117c3731233f2.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/310"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<h1>四.包引用</h1>
<p>现在我们运行了我们创建的第一个工程.<br>
那如果我这个hello.go类想引用我写的另一个string.go类的方法.<br>
该怎么实现呢.</p>
<p>1.首先创建string.go类</p>
<div class="image-package">
<div class="image-container" style="max-width: 700px; max-height: 76px">
<div class="image-view" data-width="811" data-height="76"><img src="//upload-images.jianshu.io/upload_images/1452166-355d9a01d8507e77.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/811"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>2.代码如下<br>
这里Reverse方法实现的功能是吧字符串倒序输出<br>
如Hello => olleH</p>
<div class="image-package">
<div class="image-container" style="max-width: 316px; max-height: 170px">
<div class="image-view" data-width="316" data-height="170"><img src="//upload-images.jianshu.io/upload_images/1452166-9b3a476f111e1ceb.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/316"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>3.回到hello.go类<br>
importstring类.<br>
在输出的地方调用string类的Reverse方法.并且输出返回结果</p>
<div class="image-package">
<div class="image-container" style="max-width: 415px; max-height: 158px">
<div class="image-view" data-width="415" data-height="158"><img src="//upload-images.jianshu.io/upload_images/1452166-a5c0ee9c478e482a.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/415"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>4.install<br>
重新install hello.go类.<br>
并且运行hello<br>
发现结果成功变成了倒序.</p>
<div class="image-package">
<div class="image-container" style="max-width: 291px; max-height: 64px">
<div class="image-view" data-width="291" data-height="64"><img src="//upload-images.jianshu.io/upload_images/1452166-2e53c62d85c2a859.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/291"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<blockquote>
<p>小问题:<br>
直接在终端export修改环境变量.<br>
只在当前这次进程起作用<br>
如果想永久性改变<br>
需要修改~/.zshrc文件 (zsh用户)<br>
(bash用户修改~/.bashrc)</p>
</blockquote>
<p>将上面export的写入~/.zshrc文件<br>
然后运行source ~/.zshrc</p>
<h1>五.单元检测</h1>
<p>你写完了一个功能.没有单元检测肯定是不行的.<br>
那单元检测在go里怎么写呢.</p>
<p>1.在string文件夹里创建string_test.go</p>
<div class="image-package">
<div class="image-container" style="max-width: 700px; max-height: 72px">
<div class="image-view" data-width="817" data-height="72"><img src="//upload-images.jianshu.io/upload_images/1452166-0ec96d44b33bd504.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/817"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>2.代码如下<br>
这里是检测了三种案例<br>
Backward<br>
Hello,世界<br>
“”<br>
并且给出了期望的正确结果</p>
<div class="image-package">
<div class="image-container" style="max-width: 551px; max-height: 319px">
<div class="image-view" data-width="551" data-height="319"><img src="//upload-images.jianshu.io/upload_images/1452166-7f37a3ede09576d8.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/551"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>3.运行单元测试go test</p>
<div class="image-package">
<div class="image-container" style="max-width: 668px; max-height: 104px">
<div class="image-view" data-width="668" data-height="104"><img src="//upload-images.jianshu.io/upload_images/1452166-26b1ae079739b02b.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/668"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>4.发现出错了.<br>
我们发现中文乱码了.<br>
回到string.go类.<br>
我们发现输入的接受类型为byte.他不支持utf-8<br>
那我们可以改成rune就可以了.如下</p>
<div class="image-package">
<div class="image-container" style="max-width: 337px; max-height: 154px">
<div class="image-view" data-width="337" data-height="154"><img src="//upload-images.jianshu.io/upload_images/1452166-b46a88d943cf0083.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/337"></div>
</div>
<div class="image-caption">go.png</div>
</div>
<p>5.再次运行test<br>
开不开森.运行成功啦.</p>
<div class="image-package">
<div class="image-container" style="max-width: 242px; max-height: 47px">
<div class="image-view" data-width="242" data-height="47"><img src="//upload-images.jianshu.io/upload_images/1452166-fa066c494275f7d9.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/242"></div>
</div>
<div class="image-caption">go.png</div>
</div>
</div>
<br><br>作者:Sunxxxxx丶<br>链接:https://www.jianshu.com/p/6313e0460a44<br>来源:简书<br>简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。</div><br><br>
来源:https://www.cnblogs.com/fengff/p/11434399.html
頁:
[1]