Golang语言编程规范

一.说明

  1. 编程规范好,可避免语言陷阱,可有利团队协作,有利项目维护。
  2. 正常的Go编程规范有两种:编译器强制的(必须的),gofmt格式化非强制的(非必须)。
  3. Go宣告支持驼峰命名法,排斥下划线法。
  4. 自定义原则:

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

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

c.规范注释

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

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

二.代码组织结构

  1. (M)一个目录只包含一个包,模块复杂拆分子模块/子目录
  2. (S)内部项目GOPATH如果指向多个工作目录。公开项目为第一个工作区间(即go get默认下载到第一个目录)
  3. (M)非测试文件(*_test.go)禁止使用,简化包
  4. (M)禁止相对路径导入包
  5. (S)建议goimports或者IDE管理import
  6. (S)项目rep需要包含所有的代码,依赖库放在vendor下
  7. (S)建议使用Golide,Godep管理第三方包

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

三.代码风格

  1. (M)提交代码时gofmt格式化代码,golint检查代码(使用IDE时默认这两个工具会自动用到)
  2. (S)json字符串建议使用反单引号(`)
  3. (M)文件名必须小写,允许下划线'_’,但头尾不能。避免与_test.go或者系统相关_386.go等冲突
  4. (S)文件名以功能为指引,不需要再出现模块名
  5. (M)目录名必须小写,允许中划线'-',但头尾不能
  6. (S)不建议目录名出现下划线'_'
  7. (M)包名必须全部小写,无下划线,越短越好,尽量不要与标准库重名,禁止通过中划线连接多个单词
  8. (S)包名尽量与目录名一致
  9. (M) 函数名和结构体名必须为大小写驼峰模式,最好不带特殊字符如划线等
  10. (S)函数名建议动词或者动宾结构单词,结构体建议名词或者动名词
  11. (S)常量和枚举名,大小写驼峰法,不允许下划线,第三方包例外。
  12. (M)函数参数首字母小写,不能有下划线,按大小驼峰法
  13. (S)函数参数按紧密程度安排位置,同类型参数应该相邻
  14. (S)参数不大于5个
  15. (M)变量名不允许下划线,大小写驼峰法,局部变量首字母小写,全局变量首字母大写
  16. (S)避免全局变量多使用,for循环可用单字母
  17. (M)接口名大小写驼峰法,首字母大写,不能下划线,名词
  18. (S)接口名'er'结尾
  19. (M)复杂功能请多写注释备注,注释表达需清晰,不要啰嗦。注释标准暂时不强制,最好参考godoc,如包注释使用/**/,首字母大写,注释后空一行,函数注释写在函数上方等。

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

四. 单元测试/程序效率

  1. (S)建议少使用main方法测试,而是使用_test.go做测试
  2. (M)与其他语言类似,避免多级if或者for嵌用,代码层次需简单,绕脑层次少
  3. (M)避免傻逼命名,如IsTrue变量,if(!IsTrue).
  4. (M)请熟悉Go语言各特征,避免低效用法。请至少阅览一遍:

  1. yum -y install docker-io
  2. # 拉镜像
  3. docker pull hunterhug/gotourzh
  4. # 前台运行
  5. docker run -it -p 9999:9999 hunterhug/gotourzh
  6. # 后台运行(类似nohup)
  7. docker run -d -p 9999:9999 hunterhug/gotourzh
  8. 打开http://127.0.0.1:9999即可!

五. 一些例子

  1. package main
  2. import "fmt"
  3. func main() {
  4. buffedChan := make(chan int, 2)
  5. buffedChan <- 2
  6. buffedChan <- 3
  7. close(buffedChan) // 关闭后才能for打印出,否则死锁
  8. //close(buffedChan) // 不能重复关闭
  9. //buffedChan <- 4 // 关闭后就不能再送数据了,但是之前的数据还在
  10. for i := range buffedChan { // 必须关闭,否则死锁
  11. fmt.Println(i)
  12. }
  13. buffedChan1 := make(chan int, 2)
  14. buffedChan1 <- 2
  15. buffedChan1 <- 3
  16. j, ok := <-buffedChan1
  17. fmt.Println(j, ok)
  18. j, ok = <-buffedChan1
  19. fmt.Println(j, ok)
  20. close(buffedChan1) // 关闭后才能,否则死锁
  21. j, ok = <-buffedChan1 // 如果未关闭,否则堵塞后死锁
  22. fmt.Println(j, ok)
  23. select {
  24. case j, ok := <-buffedChan1:
  25. fmt.Println("jjj", j, ok)
  26. default:
  27. fmt.Println("will not out")
  28. }
  29. }

Golang语言编程规范的更多相关文章

  1. Uber Go 语言编程规范

    目录 Uber Go 语言编程规范 1. 介绍 2. 编程指南 3. 性能相关 4. 编程风格 5. 编程模式(Patterns) 6. 总结 Uber Go 语言编程规范 相信很多人前两天都看到 U ...

  2. 华为C语言编程规范

    DKBA华为技术有限公司内部技术规范DKBA 2826-2011.5C语言编程规范2011年5月9日发布 2011年5月9日实施华为技术有限公司Huawei Technologies Co., Ltd ...

  3. linux shell语言编程规范安全篇之通用原则【转】

    shell语言编程规范安全篇是针对bash语言编程中的数据校验.加密与解密.脚本执行.目录&文件操作等方面,描述可能导致安全漏洞或风险的常见编码错误.该规范基于业界最佳实践,并总结了公司内部的 ...

  4. C语言编程规范

    C语言编程规范 6 函数与过程 6.1 函数的功能与规模设计 函数应当短而精美,而且只做一件事.不要设计多用途面面俱到的函数,多功能集于一身的函数,很可能使函数的理解.测试.维护等变得困难. 6.2 ...

  5. C语言编程规范试题(标准答案)

    C语言编程规范试题(标准答案) 一.单选题(每小题3分,共20小题60分) 1.1-1.5    B D A C B                1.6-1.10    C A D B C 1.11 ...

  6. C语言编程规范试题

    C语言编程规范试题 [说明]: 1.本试题中不考虑头文件引用问题(假定已经包含正确的头文件),C语言的标准函数都可用: 2.如果不特别说明,假定程序运行环境为:操作系统Windows 2000, VC ...

  7. C++语言编程规范

    前言 这里参考了<高质量C++C 编程指南 林锐>.<google C++编程指南>以及<华为C++语言编程规范>编写了这份C++语言编程规范文档,以合理使用 C+ ...

  8. 单片机C语言编程规范

    一.基本要求 1.1 程序结构清析,简单易懂,单个函数的程序行数不得超过100行. 1.2 打算干什么,要简单,直接了当,代码精简,避免垃圾程序. 1.3 尽量使用标准库函数和公共函数. 1.4 不要 ...

  9. C语言编程规范—命名规则

    C是一门朴素的语言,你使用的命名也应该这样.与Modula-2和Pascal程序员不同,C程序员不使用诸如“ThisVariableIsATemporaryCounter”这样“聪明”的名字.C程序员 ...

随机推荐

  1. Go 语言入门(一)基础语法

    写在前面 在学习 Go 语言之前,我自己是有一定的 Java 和 C++ 基础的,这篇文章主要是基于A tour of Go编写的,主要是希望记录一下自己的学习历程,加深自己的理解 Go 语言入门(一 ...

  2. 超详细Qt5.9.5移植攻略

    本文就来介绍下如何将Qt5.9.5移植到ARM开发板上. 以imx6开发板为例,使用Ubuntu14.04虚拟机作为移植环境. 准备工作 1.主机环境:Ubuntu14.04: 开发板:启扬IAC-I ...

  3. 简易的CRM系统案例之易的CRM系统案例之JSP+MySQL+SSH框架版本

    主要对上一篇hibernate与Spring进行整合改进 简易的CRM系统案例之Struts2+Hibernate3+JSP+MySQL版本 bean-base.xml <?xml versio ...

  4. NewLife.XCode 上手指南

    想了解什么是XCode 在这里我不对XCode做过多介绍,XCode曾经是一个轻量级ORM组件,现在是一个重量级数据映射框架,支持实体对象数据到不同媒体的数据映射,提供面向对象的方式操作数据库,解决9 ...

  5. osg qt fbx

    void TeslaManage::loadModelFile(QString &filename) { file_node = osgDB::readNodeFile(std::string ...

  6. UI——DOM

    原文链接:Introduction to the DOM Introduction The Document Object Model, usually referred to as the DOM, ...

  7. SpringCloud学习成长之十三 断路器聚合监控

    上一篇文章讲述了如何利用Hystrix Dashboard去监控断路器的Hystrix command.当我们有很多个服务的时候,这就需要聚合所以服务的Hystrix Dashboard的数据了.这就 ...

  8. Linux下通过shell进MySQL执行SQL或导入脚本

    这条命令表示通过用户名和密码执行shell然后在shell里面执行一个建表语句: USER="root" PASS="root" mysql -u $USER ...

  9. Python3之使用枚举类

    当我们需要定义常量时,一个方法是用大写变量通过整数来定义,例如月份 JAN = 1 FEB = 2 MAR = 3 APR=4 May=5 Jun=6 Jul=7 Aug=8 Sep=9 Oct=10 ...

  10. jenkins:忘记密码怎么办

    方法一: 去掉密码登录配置 修改 JENKINS_HOME/users/user.conf user.conf 就是忘记密码对应的用户针对 yum install jenkins 安装的Jenkins ...