How to Write Go Code

栏目: Go · 发布时间: 7年前

内容简介:本文为官方文档How to Write Go Code的阅读总结:go tool要求代码结构遵循固定的规范。默认是$HOME/go,可以通过GOPATH环境变量修改。

本文为官方文档How to Write Go Code的阅读总结: https://golang.org/doc/code.html

概览

  • 介绍一些基本概念和规范。
  • 介绍如何写package和使用go tool。

代码结构

go tool要求代码结构遵循固定的规范。

规范概要

  • 所有 go 代码都放在一个workspace下,也就是workspace下包含多个repository。
  • 每个repository可以包含多个package,每个package也可以包含多个go代码文件。
  • package所在目录的路径就是它的import path。

workspace

默认是$HOME/go,可以通过GOPATH环境变量修改。

  • workspace下的src子目录用于存放repository源码。
  • bin子目录用于存放go tool生成的可执行文件。

注意点:文中说workspace下不应使用软链,原因尚不明确。

GOPATH

GOPATH环境变量的作用是指定workspace的路径。

可以通过执行go env GOPATH检查确认当前的workspace设置。

技巧:go env可以查看所有GO环境变量。

import paths

package类型可以分三种:

  • go语言标准库里的package。
  • 本地workspace下的package。
  • 远端repository。

注意点:自己的package不要跟标准库的package名字相同。

first program/library and using go tool

首先创建一个目录作为package,然后在这个package下编写代码文件。

文中将代码分成了两个类型

  • 待main函数的代码,叫command source或program。
  • 不带main函数的代码,叫package source或library。

go tool

  • 对于command source,执行go install package会编译生成可执行文件,并安装到bin子目录。
  • 对于package source,执行go install package会生成.a目标文件,放在 pkg子目录。(本人测试过。)

另说明:文中提到执行go build package会将编译后的package放在local build cache中,经查1.10以前的版本没有build cache,按照本人测试机1.9.4版本go help build的说法,对于non-main package,go build package执行完后会删除目标文件,因此只起到证明package可以build的作用。

技巧及注意点:

  • go tool命令后面跟的package名,必须是相对src目录的路径,不是相对当前目录的路径。
  • 当前目录是package时,可以直接执行go tool命令,不用跟package名。
  • go tool只会在出错时有输出,因此无输出就是执行正常。

package name

几条规则和规范:

  • 所有go代码文件第一行必须是package name。
  • 同一个package里的代码文件必须是同一个package name。
  • 按惯例,package name就是import path的最后一级目录名。
  • 可执行代码文件必须是package main。
  • package name没有必要是唯一的,只需要import path唯一即可。

Test

go语言包含一个轻量级的测试框架,有两部分:

  • 一个package:testing。
  • 一个命令:go test package。

规范:

  • 测试代码文件以*_test.go命名。
  • import “testing”。
  • 测试函数以TestXXX命名,以*testing.T为参数。
  • 调用t.Error或t.Fail表示失败。
package stringutil
import "testing"
func TestReverse(t *testing.T){
}

Remote packages

go get命令会执行fetch,build,install等步骤。

包含remote package的项目且remote package没被拉到本地时,需要用go get,用go install不行。

疑问

  • rune

参考资料


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

CSS权威指南(第三版·英文影印版)

CSS权威指南(第三版·英文影印版)

[美] Eric A.Meyer / 东南大学出版社 / 2007-06 / 68.00元

著名的CSS专家Eric A.Meyer他招牌式的智慧和无与伦比的经验引领读者探索了CSS的各个部 分,包括属性、标记、特性和实现。此外,他还就现实应用中的一些问题,例如浏览器的支持和设计方针,发表了看法。你所要知道的就是HTML 4.0的知识,这样就可以创建整洁、易于维护的脚本,以与桌面出版系统同样的优雅和控制能力管理网站布局和分页。你将会学到: 精妙地设计文本风格 用户界面、......一起来看看 《CSS权威指南(第三版·英文影印版)》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具