Golang的命名规范

本文详细介绍了Golang的命名规范,包括包、文件、结构体、接口、函数、变量、常量、错误处理、单元测试及预定义标识符的命名规则,强调了大小写在决定对外暴露性上的作用,以及各种命名风格的适用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


Golang是一门区分大小写的语言。

命名规则涉及到:变量,常量,全局函数,结构,接口,方法。


## 一、大小写规范
  1. 任何需要对外暴露的名字,都必须以大写字母开头。

    当命名以1个大写字母开头时,如:GetUserName,那么使用这种形式的标识符的对象,就可以被外部包的代码使用(外部需要先导入这个包),这个过程也被称为导出。

  2. 不需要对外暴露的名字,以小写字母开头。

    当命名以1个小写字母开头时,如:getUserName,那么该对象就是对包外不可见的,但是在整个包的内部都是可见并且可用的。


二、包的命名规范

  1. 保持包名称和目录名称一致。即package main对应main的文件夹目录
  2. 尽量采用一些简短直观的包名称,不与标准库产生冲突。
  3. 包名称一般为全小写的单词,不使用下划线或者混合的大小写。

示例:

package dao
package service

三、文件的命名规范

  1. 尽量采用一些简短直观的文件名称。
  2. 文件名称一般为小写的单词,使用下划线分隔各个单词。

示例:

customer_dao.go

四、结构体的命名规范

  1. 命名简短直观。
  2. 一般采用驼峰命名法,首字母根据访问情况控制大写或小写。
  3. struct的声明和初始化采用多行书写。

示例:

type CustomerOrder struct {
    Name string
    Address string
}
order := CustomerOrder{"Tom", "北京市海淀区"}

五、接口/函数的命名规范

  1. 命名简短直观。
  2. 和结构体类似,一般采用驼峰命名法,首字母根据访问情况控制大写或小写。
  3. 以大写字母开头的函数(公有,包外可见),应该添加注释。
  4. 声明和初始化采用多行书写。
  5. 单个接口/函数的命名一般以er结尾作为后缀,例如:Reader, Writer

示例:

type Reader interface {
    Read(p []byte) (n int, err error)
}

六、变量的命名规范

  1. 命名简短直观。

  2. 和结构体、函数/接口类似,一般采用驼峰命名法,首字母根据访问情况控制大写或小写。

  3. 如果遇到特有名词(缩写或简称,如:DNS),需要遵循以下规则:

    若变量为私有,且特有名词为首个单词,则全部小写,如:appService

    若变量为公有,则特有名词全部大写。

    若变量为bool类型,则名称以Has, Is, Can, Allow开头。

示例:

var isExit bool
var hasConflict bool
var canManage bool
var allowGitHook bool

七、常量的命名规范

  1. 命名简短直观。
  2. 单词使用全部大写,并使用下划线分词。
  3. 若为枚举类型的常量,则需要先创建相应类型。

示例:

type Scheme string		//为枚举类型常量创建相应类型
const {
    HTTP Scheme = "http"
    HTTPS Scheme = "https"
}

八、错误处理的命名规范

错误处理的原则:

  1. 不能丢弃任何有返回err的调用,不使用_丢弃,必须全部处理。
  2. 接收到错误时,要么返回err,或者使用log记录下来,尽早return。
  3. 一旦有错误发生,马上返回,尽量不使用panic,除非知道错误处理时应该做什么。
  4. 如果用英文进行错误描述,必须为小写,不需要使用标点结尾,采用独立的错误流进行处理。

示例:

// 正确写法
// 若产生错误
if err != nil {
    // 进行错误处理
    return //或者continue
}
// 若没产生错误,则进入正常代码

// 错误写法
if err != nil {
    // 进行错误处理
    return //或者continue
} else {
    // 正常代码
}

九、单元测试的命名规范

  1. 一般情况下,测试用例函数名称以Test开头,如:TestExample
  2. 每个重要的函数都要首先编写测试用例,测试用例和正规代码一起提交,方便进行回归测试。
  3. 单元测试文件名,一般使用小写单词,用下划线连接,命名示例为:example_test.go

十、系统的预定义标识符

除了保留关键字之外,Golang语言系统还提供了36个预定义标识符,包括基础数据类型系统内嵌函数(不需要引入包,可以直接使用的函数)。

预定义标识符预定义标识符预定义标识符预定义标识符预定义标识符预定义标识符
appendboolbytecapclosecomplex
complex64complex128uint16copyfalsefloat32
float64imagintint8int16uint32
int32int64itoalenmakenew
nilpanicuint64printprintlnreal
recoverstringtrueuintuint8uintprt
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值