golang 初始化顺序

栏目: Go · 发布时间: 7年前

1.import机制

●  main -> import pkg1 -> const -> var ... -> init() -> main()

●  pkg1 -> import pkg2 -> const -> ...

●  pkg2 -> ...

import(
    "time"                       //普通写法
    . "fmt"                       //使用此包内的成员时不带fmt前缀
    j "encoding/json"    //json包重命名
                                     // 引入包顺序遵循 标准库,项目包,第三方包 
)

不要使用相对路径引入包(以GOPATH/src作为根目录)

import 后面跟着包路径。go语言的惯例只是一个特例,即恰好目录名与包名一致。import中的foo只是一个文件系统的路径。而下面foo.Foo()中的foo则是包名。而这个包是在src/foo目录下的源码中找到的。

2. init函数

init函数可以在任何包中有0个或1个或多个; init函数和main函数都不能被显示调用;

但这无论是对于可读性还是以后的可维护性来说,强烈建议用户在一个package中每个文件只写一个init函数。

3. 变量初始化顺序

全局变量初始化若有需要依赖其它变量,则被依赖的变量先初始化。但局部变量这样的话就会报错

    var a int = b + 1
    var b int = 1
 

下面例子会报 "initialization loop" 错误

   var a = b
   var b = c
   var c = a

4. 类型检查

Go编译器可以从初始化表达式的右值推导出该变量应该声明为哪种类型,这让 Go 语言看起来有点像动态类型语言,但是Go语言实际上是强类型语言(静态类型语言)


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

函数式算法设计珠玑

函数式算法设计珠玑

Richard Bird / 苏统华、孙芳媛、郝文超、徐琴 / 机械工业出版社 / 2017-4-1 / 69.00

本书采用完全崭新的方式介绍算法设计。全书由30个珠玑构成,每个珠玑单独列为一章,用于解决一个特定编程问题。这些问题的出处五花八门,有的来自游戏或拼图,有的是有趣的组合任务,还有的是散落于数据压缩及字串匹配等领域的更为熟悉的算法。每个珠玑以使用函数式编程语言Haskell对问题进行描述作为开始,每个解答均是诉诸于函数式编程法则从问题表述中计算得到。本书适用于那些喜欢学习算法设计思想的函数式编程人员、......一起来看看 《函数式算法设计珠玑》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具