Go init函数的详细说明
init函数通常用于:
- 变量初始化
- 检查/修复状态
- 注册器
- 运行计算
包初始化
为了使用导入的程序包,必须首先对其进行初始化。初始化始终在单个线程中执行,并且以程序包依赖关系的顺序执行。这由Golang的运行时系统控制,如下图所示:
- 初始化导入的包(递归导入)
- 计算并为块中声明的变量分配初始值
- 在包中执行初始化函数
initial.go
执行结果
function s() —>
init function —>
main —>
即使程序包被多次导入,初始化也只需要一次。
特性
init函数不需要传入参数,也不需要返回任何值。与main相比,init没有声明,因此无法引用。
undefined:init每个源文件可以包含一个以上的init函数,请记住,写在每个源文件中的“行进方式”只能包含一个init函数,这有点不同,因此进行下一个验证。
从上面的示例中,您可以看到每个源文件可以包含多个init函数。
初始化函数的一个常见示例是设置初始表达式的值。
因为不可能在上面的代码(这是一条语句)中将for循环用作预先计算的值,所以可以使用init函数来解决此问题。
Go套件汇入规则的副作用
Go非常严格,不允许引用未使用的软件包。但是有时您引用包只是为了调用init函数进行一些初始化。空标识符(即下划线)的目的是解决此问题。
摘要
以上是本文的全部内容。希望本文的内容对您的学习或工作具有参考价值。
译文地址:https://learnku.com/go/t/47178
更多编程相关知识,请访问:编程视频!!