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 层的代码
}
相关推荐
weixin_421725265 小时前
Linux 编程语言全解析:C、C++、Python、Go、Rust 谁更强?
linux·python·go·c·编程语言
yyyyyyyuande9 小时前
LSEG美股行情接入经验分享
性能优化·go
明月_清风10 小时前
Go 函数设计的工程智慧:多返回值、闭包与那些"反直觉"的选择
后端·go
却尘10 小时前
一个 `&` 引发的血案:改完配置 pipeline 装聋作哑,顺便重学了 Python/Go/Java
后端·go
我叫黑大帅11 小时前
最简单的生产-消费者,你都会遇到哪些问题?
后端·面试·go
喵个咪17 小时前
Kratos 生态双定时器中间件:高精度 hptimer 与标准 cron 选型与实践
后端·微服务·go
用户3983461612017 小时前
Go-Spring 实战第 4 课 —— 配置校验:使用 expr 标签拦截非法配置
spring·go
传说之后17 小时前
Go Context 完全指南:树状级联、超时控制、值传递与最佳实践
后端·go
用户3983461612017 小时前
Go-Spring 实战第 2 课 —— 配置绑定:Properties 映射到 Go 类型
spring·go
用户3983461612017 小时前
Go-Spring 实战第 3 课 —— 复杂类型的配置绑定:Duration、Time、Slice、Map
spring·go