Go命名规则【1】文件命名的“潜规则”

cron下面有一个刷新缓存的文件,我原来是refresh_cache.go,标准写法是这样的么?还是refreshCache.go?还是refresh-cache.go

在 Go 语言中,文件命名有一套非常明确的"潜规则"。对于你的 refresh_cache.go,建议如下:

1. 结论:首选 refresh_cache.go (下划线命名)

在 Go 项目中,小写 + 下划线 是最标准、最常见的写法。

  • refresh_cache.go:推荐。符合 Go 社区主流习惯,清晰易读。
  • refreshCache.go:不推荐。Go 的文件名几乎不使用驼峰式(驼峰通常只用于变量、结构体和函数名)。
  • refresh-cache.go:不推荐。中划线在某些构建工具或特定场景下可能会引起误解,Go 官方标准库中极少见到。

2. 为什么选下划线?

Go 的源码(标准库)几乎统一使用下划线命名法。

  • 例如:runtime/internal/atomic/atomic_test.gonet/http/internal/chunked_test.go
  • 系统适配性:下划线在所有操作系统(Windows, Linux, macOS)的文件系统中兼容性最好,且不会因为大小写敏感问题导致编译失败。

3. 更进阶的"Go 味道"写法

如果你的 cron 目录下有很多文件,Go 开发者有时会追求更短的命名,或者根据功能命名:

  • 如果该目录下只有缓存相关的定时任务:可以直接叫 cache.go
  • 如果是一个具体的清理动作:可以叫 clear_cache.go

4. 目录组织建议

既然你在做微服务,cron 目录下的代码组织通常有两种风格:

  • 风格 A(平铺式):

    复制代码
    internal/cron/
    ├── refresh_cache.go
    ├── sync_order.go
    └── scheduler.go  // 用于注册所有定时任务的入口
  • 风格 B(模块化):如果某个任务特别复杂。

    复制代码
    internal/cron/
    └── cache_task/
        ├── handler.go
        └── loader.go

总结

直接把文件名定为 refresh_cache.go 即可。

另外提醒一点:在 refresh_cache.go 内部,定义的函数名应该是驼峰式的,例如:

复制代码
package cron

// 函数名要大写驼峰(如果要被外面调用)
func RefreshCacheHandler() {
    // 调用 logic 层的代码
}
相关推荐
GetcharZp18 分钟前
告别OOM!用Go+libvips实现30000×50000超大图片的流式瓦片服务
后端·go
妙码生花3 天前
从 PHP 到 AI + Golang,程序员自救转型手记(八):设计管理员模型、热重载配置
前端·后端·go
tyung4 天前
Go 手写 Wait-Free MPSC 无界队列:SwapPointer 实现多生产者无锁入队
后端·go
陈明勇4 天前
Go 1.26 新特性回顾:语言增强、工具升级与 Green Tea GC 默认启用
后端·go
妙码生花5 天前
从 PHP 到 AI + Golang,程序员自救转型手记(二):目录结构、初始化 GIT、设计并开发配置系统
前端·后端·go
leeyi5 天前
Deer-Go:字节 Deer-Flow 的 Go 移植,深度研究 Agent 全拆解
go·aigc·agent
Bolt6 天前
TypeScript 7.0 来了:当 tsc 用 Go 重写之后
javascript·typescript·go
Go_error6 天前
Datatypes:Go 轻松支持数据库JSON类型
后端·go
任沫7 天前
Agent之Function Call
javascript·人工智能·go
唐青枫7 天前
别再把 interface 当万能盒子:Go 接口从隐式实现到项目解耦
go