文章目录
- 1. 项目目录结构
- 2. 创建自定义包
- 3. 初始化模块
- 4. 导入自定义包
- 5. 相对路径导入
在Go语言中导入自定义包需要遵循一定的目录结构和导入规则。以下是详细指南(包含两种方式):
1. 项目目录结构
方法1:适用于Go 1.11+ ,使用 Go Modules 管理依赖。
Go Modules(go.mod) 是官方推荐的依赖管理工具,自 Go 1.11(2018年) 起引入,并在 Go 1.16(2021年) 后成为默认模式。
也可使用go help查看是否有该工具。
myproject/
├── go.mod // 模块定义文件
├── main.go // 主程序
└── mypackage/ // 自定义包└── mypackage.go
方法2、如果你的 Go 版本较旧(如 Go 1.10 或更早),确实没有 go mod 功能,而是使用 GOPATH 模式管理包。这里则需要手动导入包。新版本该功能向下兼容。
myproject/
├── main.go // 主程序
└── mypackage/ // 自定义包└── mypackage.go
2. 创建自定义包
在mypackage/mypackage.go中:
package mypackage // 包声明必须与目录名一致import "fmt"// 可导出的函数(首字母大写)
func SayHello() {fmt.Println("Hello from mypackage!")
}// 可导出的变量
const Version = "1.0.0"
3. 初始化模块
适用于Go 1.11+ 版本的方法一。
在项目根目录执行:
bash
go mod init github.com/yourusername/myproject
这会创建go.mod文件,内容类似:
module github.com/yourusername/myprojectgo 1.21
4. 导入自定义包
适用于Go 1.11+ 版本的方法一。
package mainimport ("fmt""github.com/yourusername/myproject/mypackage" // 导入自定义包
)func main() {// 调用自定义包中的公共函数mypackage.SayHello()// 访问自定义包中的公共变量fmt.Println("Package version:", mypackage.Version)
}
5. 相对路径导入
适用于Go 1.11以下 版本的方法二。
package mainimport "fmt"
import "./mypackage" // 不推荐长期使用func main() {// 调用自定义包中的公共函数mypackage.SayHello()// 访问自定义包中的公共变量fmt.Println("Package version:", mypackage.Version)
}