Go命名规则【2】全场景命名避坑指南

好乱呀,文件名是下划线分隔,函数名是大小写,那么URL呢?是中划线吗?

Go 语言初学者最容易在这些"起名规范"里绕晕,因为 Go 在不同场景下的审美标准完全不一样。

我帮你整理了一张"全场景命名避坑指南",你按这个表来就不会乱了:

1. 开发中的四大命名规则

场景 推荐格式 示例 理由
文件名 下划线 refresh_cache.go Go 官方标准库风格,兼容性最强。
Go 函数/变量 驼峰式 GetUserInfo / isReady Go 语言强制规范,导出变量首字母必须大写。
URL 路径 中划线 /api/v1/user-profile SEO 友好,且在浏览器地址栏最易读,也是 RESTful 标准。
JSON 字段 下划线 {"user_id": 1} 跨语言标准,前端 JavaScript/Python 处理最顺手。

2. 深度解析:为什么 URL 推荐中划线?

在 HTTP API 设计中,URL 路径(Path)推荐使用 kebab-case(中划线),原因如下:

  • RFC 规范:域名是不区分大小写的,虽然路径区分,但为了统一,大家习惯全部小写。
  • 可读性:/api/user_profile(下划线)在带有下划线的超链接里,下划线会被链接本身的横线遮住,看不清是空格还是符号。而 /api/user-profile 永远清晰。
  • 大厂惯例:Google、GitHub 等主流 API 几乎全部采用中划线。

3. 一个典型的代码片段(串联所有规范)

看这段代码,你就知道它们是怎么共存的了:

复制代码
// 文件名: internal/handler/user_handler.go (下划线)

package handler

// 结构体字段用 JSON 标签定义下划线 (JSON规范)
type UserResponse struct {
    UserName string `json:"user_name"` 
}

// 函数名用驼峰 (Go规范)
func GetUserHandler(c *gin.Context) {
    // 逻辑...
}

// 路由注册 (URL规范)
// 浏览器访问: http://api.com
r.GET("/get-user-info", GetUserHandler) 

4. 总结你的疑惑

  1. 文件:refresh_cache.go
  2. 函数:func RefreshCache()
  3. URL:/api/refresh-cache ✅(如果是内部 API,/api/refresh_cache 也能用,但不标准)

心态建设:

Go 是一门"强迫症"语言。你只需要记住:"给电脑看的文件名用下划线,给人看的网址用中划线,给 Go 编译器看的函数用驼峰"。

相关推荐
用户398346161202 小时前
Go-Spring 实战第 1 课 —— 统一配置模型:Properties 与 Path
go
王中阳Go4 小时前
秒杀、分库分表、全链路追踪:一个电商微服务的架构全拆解
后端·go
漓漾li6 小时前
每日面试题(2026-05-15)
架构·go·agent
tyung7 小时前
用 Go 实现一个生产级 Ring Buffer Queue:环形数组、位运算取模、批量操作全拆解
数据结构·go
Wy_编程12 小时前
golang 基础语法和函数
开发语言·go
养肥胖虎1 天前
Docker学习笔记:后端、数据库和反向代理怎么一起跑起来
后端·nginx·docker·postgresql·go·部署
君万3 天前
【LeetCode每日一题】3. 无重复字符的最长子串 560. 和为 K 的子数组
算法·leetcode·golang·go
用户095367515833 天前
Go:浮点数如何进行比较?
后端·go
漓漾li4 天前
每日面试题-Go全栈AI agent
go·agent·全栈