0

0

Golang package包名命名规范说明

P粉602998670

P粉602998670

发布时间:2026-01-07 09:39:02

|

973人浏览过

|

来源于php中文网

原创

Go包名必须全小写、无下划线或驼峰,与目录名严格一致,避免泛化名如utils,导入路径与包名协同设计,且对外暴露后不可更改。

golang package包名命名规范说明

包名必须全小写且不能含下划线或驼峰

Go 官方明确不鼓励、社区几乎从不使用 _ 或大小混写(如 myPackageuser_auth),因为这会破坏工具链兼容性(比如某些文件系统区分大小写)、增加拼写错误风险,也违背标准库一贯风格。你看到的 fmtnet/httpencoding/json 全是纯小写单词或路径段。

  • ✅ 正确:cacheauthstrutilhttpclient
  • ❌ 错误:Cacheuser_utilsHTTPClientjson_parser
  • ⚠️ 注意:http 是合法包名,尽管它是缩写——Go 接受常见英文缩略词,但不接受自造缩写如 usr(应写 user

包名必须与目录名严格一致

这不是语法强制,但 Go 工具链(go buildgo test、IDE 跳转)和所有主流 CI/CD 流程都默认依赖这一约定。一旦不一致,就会出现“找不到包”“测试无法运行”“VS Code 提示未解析导入”等隐性问题。

  • 目录结构是 myproject/auth/ → 文件开头必须是 package auth
  • 目录结构是 internal/cache/redis/ → 包名必须是 redis,不是 cache_redisrediscache
  • 如果你硬写成 package authzauth/ 目录下,go list ./auth 仍能识别,但其他开发者和自动化脚本大概率失效

避免泛化包名如 utilscommonhelpers

这类名字不表达职责,导致包边界模糊、功能堆积、后期难以拆分。Go 强调“一个包一个职责”,命名就是第一道契约。

  • ❌ 不要建一个叫 utils 的目录,把字符串、时间、加密函数全塞进去
  • ✅ 拆成语义明确的包:strutil(字符串操作)、timeutil(时间格式转换)、crypto(加解密逻辑)
  • ⚠️ 特例:errors 是标准库包名,但它承载的是 Go 错误处理的核心抽象,不是“随便放点工具函数”的容器 —— 别拿它当借口

导入路径 ≠ 包名,但两者必须协同设计

导入路径(如 "myproject/auth")由 go.modmodule 声明决定,而包名只是该路径最后一段。混淆这两者是新人最常踩的坑:以为改了目录就能改导入路径,或以为改了包名就能解决冲突。

Kreado AI
Kreado AI

Kreado AI是一个多语言AI视频创作平台,只需输入文本或关键词,即可创作真实/虚拟人物的多语言口播视频。 为创作者提供AI赋能

下载

立即学习go语言免费学习笔记(深入)”;

  • 你的 go.modmodule github.com/you/app,那么 auth/ 目录下的包,导入路径就是 "github.com/you/app/auth",包名仍是 auth
  • 如果两个包都想叫 config(比如 auth/config.godatabase/config.go),别试图改成 authconfigdbconfig —— 应保持包名都是 config,靠不同导入路径自然隔离
  • 真遇到命名冲突(比如你要用 github.com/someone/log,但本地也有 log 包),用导入别名:import mylog "github.com/someone/log",而不是改自己包名

最易被忽略的一点:包名一旦对外暴露(比如发布为公共模块),就基本不可更改——改名等于破坏所有下游导入。所以从第一个 go mod init 开始,就该按规范定好每个子目录的包名,别留到“以后再重构”。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

177

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

226

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

336

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

208

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

388

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

194

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

189

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

191

2025.06.17

PPT动态图表制作教程大全
PPT动态图表制作教程大全

本专题整合了PPT动态图表制作相关教程,阅读专题下面的文章了解更多详细内容。

35

2026.01.07

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

Redis+MySQL数据库面试教程
Redis+MySQL数据库面试教程

共72课时 | 6.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号