美文网首页
Golang语言编程规范

Golang语言编程规范

作者: veeeeeeeeeeee | 来源:发表于2019-05-12 13:30 被阅读0次

版权所有,转载请注明:http://www.lenggirl.com/language/go-spec.html

Golang语言编程规范

一.说明

编程规范好,可避免语言陷阱,可有利团队协作,有利项目维护。

正常的Go编程规范有两种:编译器强制的(必须的),gofmt格式化非强制的(非必须)。

Go宣告支持驼峰命名法,排斥下划线法。

自定义原则:

a.统一工作区间,避免目录及文件名随意

b.规范变量/结构体/方法及接口名

c.规范注释

d.单元测试/程序效率等建议

两个等级: (S)建议,(M)必须。以下是细节。

二.代码组织结构

(M)一个目录只包含一个包,模块复杂拆分子模块/子目录

(S)内部项目GOPATH如果指向多个工作目录。公开项目为第一个工作区间(即go get默认下载到第一个目录)

(M)非测试文件(*_test.go)禁止使用,简化包

(M)禁止相对路径导入包

(S)建议goimports或者IDE管理import

(S)项目rep需要包含所有的代码,依赖库放在vendor下

(S)建议使用Golide,Godep管理第三方包

总而言之:组织结构需要简化,一目了然,允许多个工作区间,但是环境变量的第一个工作区间必须是公开的项目,最好使用一个工作区间,不要建立相对路径的包,最好用godep等依赖库控制工具来管理依赖库,每个项目所有的依赖库最好放在本目录vendor下。

三.代码风格

(M)提交代码时gofmt格式化代码,golint检查代码(使用IDE时默认这两个工具会自动用到)

(S)json字符串建议使用反单引号(`)

(M)文件名必须小写,允许下划线’_’,但头尾不能。避免与_test.go或者系统相关_386.go等冲突

(S)文件名以功能为指引,不需要再出现模块名

(M)目录名必须小写,允许中划线’-‘,但头尾不能

(S)不建议目录名出现下划线’_’

(M)包名必须全部小写,无下划线,越短越好,尽量不要与标准库重名,禁止通过中划线连接多个单词

(S)包名尽量与目录名一致

(M) 函数名和结构体名必须为大小写驼峰模式,最好不带特殊字符如划线等

(S)函数名建议动词或者动宾结构单词,结构体建议名词或者动名词

(S)常量和枚举名,大小写驼峰法,不允许下划线,第三方包例外。

(M)函数参数首字母小写,不能有下划线,按大小驼峰法

(S)函数参数按紧密程度安排位置,同类型参数应该相邻

(S)参数不大于5个

(M)变量名不允许下划线,大小写驼峰法,局部变量首字母小写,全局变量首字母大写

(S)避免全局变量多使用,for循环可用单字母

(M)接口名大小写驼峰法,首字母大写,不能下划线,名词

(S)接口名’er’结尾

(M)复杂功能请多写注释备注,注释表达需清晰,不要啰嗦。注释标准暂时不强制,最好参考godoc,如包注释使用/**/,首字母大写,注释后空一行,函数注释写在函数上方等。

总而言之,文件名和目录名,包名都必须小写。数据类型变量和参数等定义最好使用驼峰大小写法,不要使用下划线或者中划线

四. 单元测试/程序效率

(S)建议少使用main方法测试,而是使用_test.go做测试

(M)与其他语言类似,避免多级if或者for嵌用,代码层次需简单,绕脑层次少

(M)避免傻逼命名,如IsTrue变量,if(!IsTrue).

(M)请熟悉Go语言各特征,避免低效用法。请至少阅览一遍:

yum-y install docker-io# 拉镜像docker pull hunterhug/gotourzh# 前台运行docker run -it -p9999:9999hunterhug/gotourzh# 后台运行(类似nohup)docker run -d -p9999:9999hunterhug/gotourzh打开http://127.0.0.1:9999即可!

相关文章

  • Golang语言编程规范

    一.说明 编程规范好,可避免语言陷阱,可有利团队协作,有利项目维护。 正常的Go编程规范有两种:编译器强制的(必须...

  • Golang语言编程规范

    版权所有,转载请注明:http://www.lenggirl.com/language/go-spec.html ...

  • Golang 专栏

    简介 整理 Golang 相关文章,方便大家阅读。 目录 golang 编程规范 - 项目目录结构[https:/...

  • <<编程基础-语言Golang.C-C++>&

    <<编程基础-语言Golang.C-C++>>

  • Golang 编程规范

    [TOC] 介绍 本文更多的介绍代码管理和检查工具而不是大篇幅风格文档,毕竟文档不如工具扫描有时效性和可行性 代码...

  • Golang编程规范

    统一规范篇 合理规划目录 本篇主要描述了公司内部同事都必须遵守的一些开发规矩,如统一开发空间,既使用统一的开发工具...

  • 笨办法学golang(一)

    Golang简介 Go语言(或Golang)是 Google 在 2007 年开发的一种开源编程语言,于 2009...

  • Go核心编程-面向对象 [OOP]

    Golang也是支持面向对象(OOP)编程特性的语言,但是Golang中没有类(class),而Go语言的结构体(...

  • 初识go语言

    title: 初识go语言tag: golang 编程语言categories: notes 简介 Go语言是一门...

  • Golang聚合

    教程 Go Web 编程Go语言圣经(中文版) Tips Golang 学习笔记——交叉编译 & 部署Golang...

网友评论

      本文标题:Golang语言编程规范

      本文链接:https://www.haomeiwen.com/subject/jcrcaqtx.html