golang 之 import 和 package 的使用

big_cat · · 11265 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

golang 使用包 package 来管理定义模块,可以使用 import 关键字来导入使用。

  • 如果导入的是 go 自带的包,则会去安装目录 $GOROOT/src 按包路径加载,如 fmt 包
  • 如果是我们 go get 安装或自定义的包,则会去 $GOPATH/src 下加载

package 的定义

go import 的包是由 包路径/包名 组合而成的,例如导入我们自定义的 baz 包,包路径为 $GOPATH/src/foo/bar/baz,baz 包的源码都存放在此目录下。

我们需要规范的将 baz 包中源码的 package 定义为 baz,就定义好一个可 import 载入的的包了。

hello 模块

//$GOPATH/src/foo/bar/baz/hello.go
package baz

import (
    "fmt"
)

// 模块初始化函数 import 包时被调用
func init() {
    fmt.Println("hello module init function")
}

func Hello() {
    return "hello"
}

world 模块

//$GOPATH/src/foo/bar/baz/world.go
package baz

import (
    "fmt"
)

// 模块初始化函数 import 包时被调用
func init() {
    fmt.Println("world module init function")
}

func World() string {
    return "world"
}
package main

import (
    "fmt"
    "foo/bar/baz" //引入我们自定义的包
)

func main() {
    fmt.Println(baz.Hello(), baz.World())
}

import的使用

普通操作

import (
    "fmt"
    "log"
    "foo/bar/baz"
)

普通导入就是按照加载机制,将要使用的包导入进来,然后使用 packageName.MethodName 的方式调用包内的方法即可。注意如果要包方法在其他包中可以调用,包方法需要首字母大写,例如:fmt.Println() fmt.Printf()。

别名操作

package main

import (
    "fmt"
    myBaz "foo/bar/baz"
)

func main() {
    fmt.Println(myBaz.Hello(), myBaz.World())
}

如果两个包的包名存在冲突,或者包名太长需要简写时,我们可以使用别名导入来解决。

点操作

package main

import (
    "fmt"
    . "foo/bar/baz"
)

func main() {
    fmt.Println(Hello(), World()) // 直接使用包内的方法即可 不需要显式使用包名
}

. 导入可以让包内的方法注册到当前包的上下文中,直接调用方法名即可,不需要再加包前缀。

下划线操作

package main

import (
    "fmt"
    _ "foo/bar/baz"
)

func main() {
    fmt.Println(baz.Hello(), baz.World()) // 错误 _ 并没有导入包 只是引入并执行包模块的 init  方法
}

_ 是包引用操作,只会执行包下各模块中的 init 方法,并不会真正的导入包,所以不可以调用包内的其他方法。

相信对很多 phper 来说遵循 PSR4 的 Namespace 会将与路径紧密相关命名空间也作为类名的一部分,而 golang 则只将模块目录文件夹名作为包名,前面的路径只是用来导入而和包名无关,还是有一点点需要注意的。


有疑问加站长微信联系(非本文作者)

本文来自:Segmentfault

感谢作者:big_cat

查看原文:golang 之 import 和 package 的使用

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

11265 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传