文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
3.3 函数 init
每个包可以包含任意多个 init
函数,这些函数都会在程序执行开始的时候被调用。所有被编译器发现的 init
函数都会安排在 main
函数之前执行。 init
函数用在设置包、初始化变量或者其他要在程序运行前优先完成的引导工作。
以数据库驱动为例, database
下的驱动在启动时执行 init
函数会将自身注册到 sql
包里,因为 sql
包在编译时并不知道这些驱动的存在,等启动之后 sql
才能调用这些驱动。让我们看看这个过程中 init
函数做了什么,如代码清单 3-5 所示。
代码清单 3-5 `init`函数的用法
01 package postgres
02
03 import (
04 "database/sql"
05 )
06
07 func init() {
08 sql.Register("postgres", new(PostgresDriver)) ●―――― 创建一个 postgres 驱动的实例。这里为了展现 init 的作用,没有展现其定义细节。
09 }
这段示例代码包含在 PostgreSQL 数据库的驱动里。如果程序导入了这个包,就会调用 init
函数,促使 PostgreSQL 的驱动最终注册到 Go 的 sql
包里,成为一个可用的驱动。
在使用这个新的数据库驱动写程序时,我们使用空白标识符来导入包,以便新的驱动会包含到 sql
包。如前所述,不能导入不使用的包,为此使用空白标识符重命名这个导入可以让 init
函数发现并被调度运行,让编译器不会因为包未被使用而产生错误。
现在我们可以调用 sql.Open
方法来使用这个驱动,如代码清单 3-6 所示。
代码清单 3-6 导入时使用空白标识符作为包的别名
01 package main
02
03 import (
04 "database/sql"
05
06 _ "github.com/goinaction/code/chapter3/dbdriver/postgres" ●―――― 使用空白标识符导入包,避免编译错误。
07 ) 08 09 func main() 10 sql.Open("postgres", "mydb") ●―――― 调用 sql 包提供的 Open 方法。该方法能工作的关键在于 postgres 驱动通过自己的 init 函数将自身注册到了 sql 包。
11 }
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论