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