从另一个模块调用您的代码
在上一节中,您创建了一个greetings
模块。在本节中,您将编写代码以调用刚刚编写的模块中的 Hello
函数。您将编写可以作为应用程序执行的代码,并调用greetings
模块中的代码。
-
为 Go 模块源代码创建一个
hello
目录。这是您编写调用方的位置.创建此目录后,您应该在层次结构中的同一级别同时具有 hello 和 greetings 目录,如下所示:
<home>/ |-- greetings/ |-- hello/
例如,如果您的命令提示符位于 greetings 目录中,则可以使用以下命令:
cd .. mkdir hello cd hello
-
为您将要编写的代码启用依赖项跟踪.
要为您的代码启用依赖项跟踪,请运行
go mod init
命令,为其指定您的代码所在模块的名称出于本教程的目的,请使用
example.com/hello
用于模块路径。$ go mod init example.com/hello go: creating new go.mod: module example.com/hello
- 在hello 目录中用文本编辑器创建一个用于编写代码的文件,并将其命名为 hello.go
-
编写代码来调用
Hello
函数,然后打印函数的返回值。为此,请将以下代码粘贴到 hello.go 中.
package main import ( "fmt" "example.com/greetings" ) func main() { // 获取问候信息并打印出来. message := greetings.Hello("Gladys") fmt.Println(message) }
在此代码中,您:
-
声明一个
main
包。在 Go 中,作为应用程序执行的代码必须在main
包中. -
导入两个包:
example.com/greetings
和fmt
包。这使代码可以访问这些包中的函数。导入example.com/greetings
(您之前创建的模块中包含的包)使你可以访问Hello
函数。您还导入了fmt
,其中包含用于处理输入和输出文本(如将文本打印到控制台)的函数。 -
通过调用
greetings
包的Hello
函数获取问候语。
-
声明一个
-
编辑
example.com/hello
模块以使用本地example.com/greetings
模块。对于生产用途,您可以从其存储库(具有反映其已发布位置的模块路径)发布
example.com/greetings
模块,Go 工具可以在其中找到它以下载它。现在,由于尚未发布该模块,因此需要调整example.com/hello
模块,以便它可以在本地文件系统上找到example.com/greetings
代码。为此,请使用
go mod edit
命令编辑example.com/hello
模块,将 Go 工具从其模块路径(模块不在的位置)重定向到本地目录(所在的位置)。-
从 hello 目录中的命令提示符处,运行以下命令:
$ go mod edit -replace example.com/greetings=../greetings
该命令指定
example.com/greetings
应替换为../greetings
,用于查找依赖项。运行该命令后,hello 目录中的 go.mod 文件应包含一个replace
指令:module example.com/hello go 1.16 replace example.com/greetings => ../greetings
-
在 hello 目录的命令提示符下,运行
go mod tidy
命令以同步example.com/hello
模块的依赖项,添加代码所需的依赖项,但尚未在模块中跟踪的依赖项。$ go mod tidy go: found example.com/greetings in example.com/greetings v0.0.0-00010101000000-000000000000
命令完成后,
example.com/hello
模块的 go.mod 文件应如下所示:module example.com/hello go 1.16 replace example.com/greetings => ../greetings require example.com/greetings v0.0.0-00010101000000-000000000000
该命令在greetings目录中找到本地代码,然后添加了一个
require
指令来指定example.com/hello
需要example.com/greetings
。您在 hello.go 中导入greetings
包时创建了此依赖项.模块路径后面的数字是伪版本号 - 用于代替语义版本号(模块还没有)的生成的数字.
要引用已发布的模块,go.mod 文件通常会省略
replace
指令并使用末尾带有标记版本号的require
指令。require example.com/greetings v1.1.0
有关版本号的更多信息,请参阅 模块版本编号.
-
从 hello 目录中的命令提示符处,运行以下命令:
-
在
hello
目录中的命令提示符下,运行代码以确认其正常工作。$ go run . Hi, Gladys. Welcome!
恭喜!您已经编写了两个功能模块.
在下一个主题中,您将添加一些错误处理.