
在go中,同一包下的多个`.go`文件需**同时指定**给`go run`命令才能互相调用;单独运行其中一个文件时,其他同包文件不会被自动加载。
Go 采用显式、扁平化的构建模型:go run 默认只编译并执行你明确列出的文件,即使它们位于同一目录、同属 main 包,也不会自动发现或包含未声明的同包文件。
例如,你有以下两个文件:
a.go:
package main
func foo() int {
return 42
}b.go:
立即学习“go语言免费学习笔记(深入)”;
package main
import "fmt"
func main() {
fmt.Println(foo()) // ✅ 正确调用
}❌ 错误方式(仅运行 b.go):
go run b.go # ./b.go:5: undefined: foo
此时 Go 编译器只看到 b.go,完全不知道 foo 的定义。
✅ 正确方式(显式列出所有依赖文件):
go run a.go b.go # 输出:42
✅ 更推荐的方式(运行整个目录):
go run . # 同样会编译当前目录下所有 `.go` 文件(排除测试文件),适用于多文件项目
⚠️ 注意事项:
- go run *.go 在某些 shell 中可能因通配符展开顺序或隐藏文件导致问题,不推荐;
- 所有文件必须属于同一包(如均为 package main),且无重复函数/变量定义;
- 若使用模块(go mod init),确保在模块根目录下执行命令;
- 生产环境建议使用 go build 生成可执行文件,而非反复 go run。
总结:Go 不支持“隐式导入本地文件”,其设计哲学是明确即安全——所有参与编译的源文件都必须显式声明。这是与 Python 或 Node.js 等动态语言的重要区别,也是 Go 构建确定性与可重现性的基础之一。










