1.Go语言的导包机制
Go语言除了可以导入系统自带的一些功能包,也可以导入开发人员自己导入的包,导包的过程中会默认的调用包内的init方法,这与java类的构造方法有些类似,下面举个例子感受一下Go语言的导包机制:
首先,我在当前项目文件夹下建立了三个包:分别为main、lib1和lib2
main包
package main
import (
//导入 lib1 和 lib2
"HelloWorld/lib1"
"HelloWorld/lib2"
"fmt"
)
func init() {
fmt.Println("main function ...")
}
func main() {
lib1.Testlib1()
lib2.Testlib2()
}
lib1包
package lib1
import "fmt"
//lib1 的初始化方法
func init () {
fmt.Println("lib1 init function ...")
}
// 注意,首字母大写的方法表明该方法是对外开放的
func Testlib1() {
fmt.Println("lib1 success ...")
}
lib2包
package lib2
import "fmt"
//lib2 的初始化方法
func init () {
fmt.Println("lib2 init function ...")
}
// 注意,首字母大写的方法表明该方法是对外开放的
func Testlib2() {
fmt.Println("lib2 success ...")
}
执行结果
lib1 init function ...
lib2 init function ...
main function ...
lib1 success ...
lib2 success ...
可以看到,在导入包后,会按导入顺序依次调用对应包的init方法进行初始化,然后执行main包的初始化方法,最后在main包可以调用lib1和lib2两个包对外开放的方法。
2.Go语言导包的取别名方式
在Go语言中,如果导入的包在后续没有使用的话,程序会报错,但是如果只想lib2包的初始化方法被调用但用不用其他方法要怎么实现呢?
这就是Go语言的匿名导包方式,例子:
package main
import (
"HelloWorld/lib1"
// 导入lib2包但是没有使用
_ "HelloWorld/lib2"
"fmt"
)
func init() {
fmt.Println("main function ...")
}
func main() {
lib1.Testlib1()
}
运行结果
lib1 init function ...
lib2 init function ...
main function ...
lib1 success ...
可以看到,在包前加入_代表给包匿名,导入的包虽然没有使用但是初始化方法依旧被调用了。
除此之外,对于导入的包,为了后面方便调用,也可以采用取别名的方式,如我们给lib1包取别名aalib1.这种方法对于熟悉python的小伙伴可能并不陌生。
package main
import (
// 给lib1包取别名aalib1
aalib1 "HelloWorld/lib1"
_ "HelloWorld/lib2"
"fmt"
)
func init() {
fmt.Println("main function ...")
}
func main() {
// 使用包的别名调用方法
aalib1.Testlib1()
}
运行结果
lib1 init function ...
lib2 init function ...
main function ...
lib1 success ...
当然,还有一种特殊的方式,那就是可以不使用包名,直接调用方法
package main
import (
// 给lib1包取别名aalib1
aalib1 "HelloWorld/lib1"
// 不取报名,直接导入lib2
. "HelloWorld/lib2"
"fmt"
)
func init() {
fmt.Println("main function ...")
}
func main() {
// 使用包的别名调用方法
aalib1.Testlib1()
// 直接调用lib2的方法
Testlib2()
}
运行结果
lib1 init function ...
lib2 init function ...
main function ...
lib1 success ...
lib2 success ...
可以看到,在导入lib2包时候,取别名为.的话,可以直接调用lib2中方法,但是这种方法建议使用,因为这样调用如果多个包之间有同名方法,那将引起冲突,在导入包较少而且确定没有冲突的情况下使用。