go学习笔记-包处理

包处理

package是go管理代码的重要工具,用于组织 Go 源代码,提供了更好的可重用性与可读性。

可见性

变量或函数名的首字母大写时,其就是可导出的,小写时则是不可导出的。

函数和变量的可访问性是以包做隔离的。

包          函数或变量      可访问性

同一个包    可/不可导出的     都能访问
其他的包    可导出的          可访问
其他的包    不可导出的        不能访问

main 函数和 main 包

可执行的程序都必须包含一个 main 函数。这个函数是程序运行的入口。main 函数应该放置于 main 包中,例如

package main

import "fmt"

func main() {
	fmt.Printf("hello world
")
}

创建自定义的包

属于某一个包的源文件都应该放置于一个单独命名的文件夹里。按照 Go 的惯例,应该用包名命名该文件夹。例如,我们创建名为animal的package,

目录结构

src
    animal
        dog.go

代码示例

package animal

//Fox ...
type Fox struct {
	Name string
}

//Woo ...
func (fox Fox) Woo() string {
	return fox.Name + " wooooooo"
}

其中,类型和方法首字母都是大写。

导入自定义包

为了使用自定义包,必须要先导入它。导入自定义包的语法为

import path

指定自定义包相对于工作区内 src 文件夹的相对路径。例如,animal包 导入到 main 包 中

目录结构

src
    animal
        dog.go
    main.go

代码示例

package main

import (
	"fmt"
	"animal"
)

func main() {  
    fox := animal.Fox{"fox1"}
	str := fox.Woo()
	fmt.Println(str)
}

包初始化顺序

init 函数

所有包都可以包含一个 init 函数。init 函数不应该有任何返回值类型和参数,在我们的代码中也不能显式地调用它。init 函数的形式如下:

func init() {  
}

init 函数可用于执行初始化任务,也可用于在开始执行之前验证程序的正确性。

包的初始化顺序如下:
首先初始化包级别(Package Level)的变量
紧接着调用 init 函数。包可以有多个 init 函数(在一个文件或分布于多个文件中),它们按照编译器解析它们的顺序进行调用。
如果一个包导入了另一个包,会先初始化被导入的包。
尽管一个包可能会被导入多次,但是它只会被初始化一次。

使用空白标识符(Blank Identifier)

导入了包,却不在代码中使用它,这在 Go 中是非法的。当这么做时,编译器是会报错的。其原因是为了避免导入过多未使用的包,从而导致编译时间显著增加。然而,在程序开发的活跃阶段,又常常会先导入包,而暂不使用它。遇到这种情况就可以使用空白标识符 _。

package main 

import (
    _ "geometry/rectangle" 
)
func main() {

}
原文地址:https://www.cnblogs.com/SLchuck/p/9936901.html