X.0 Go语言自己编写工具包(附本系列文章所用的tools包)

我们将建立一个自己的函数库(也就是一个非执行包),随着本系列文章的进展将逐步编写一些有用的函数放在这个包中统一管理,供其他演示代码调用。我们把这个包起名叫做“tools”,表示是一些工具类的函数。本文将演示编写其中的第一个函数Printfln。


编写该函数的原因是,fmt包中有Println函数和Printf函数,但是居然没有类t似Printfln的函数,也就是说没有又可以有格式化字符串又能自动加上换行符的输出函数。虽然Printf函数中可以用转义符“\n”代表换行,但每次都要输出该字符很麻烦,也影响代码的简洁美观。因此,我们准备编写一个Printfln函数,其功能与Printf函数基本完全相同,唯一的区别就是会自动加上一个换行符。该函数放在tools包中供其它代码来调用。


首先,我们在GOPATH指定目录下的src子目录下新建一个tools目录,并在其中新建一个tools.go文件,并录入下面的代码,


package tools


import (

  "fmt"

)


func Printfln(format string,a ...interface{}) {

  fmt.Printf(format+"\n", a...)

}

代码 4‑18 Printfln函数


代码4‑18中仅仅定义了一个函数Printfln,它所接受的参数完全与fmt.Printf函数一致,我们可以通过查看Go语言的参考文档来确认这一点。我们知道fmt.Printf函数除了第一个参数是格式化字符串之外,后面还可以有多个参数(这种可以有多个参数的情况也叫做可变长参数),分别代表需要输出的多个数值,并且数值的类型可以是Go语言中的任意类型,a ...interface{} 这个参数定义就代表了任意多个不定类型的参数,其中interface{}在Go语言中代表一种特殊类型(称作“空接口”),这种类型的参数可以传入任意类型的数据,而它前面的省略号“...”(三个英文的小数点)就代表任意个数的参数。Printfln函数中仅一行代码,就是调用fmt.Printf函数并将传入Printfln的参数原样传入到fmt.Printf函数中,唯一的区别是在格式化字符串后加上一个换行符“\n”,这样就达到了比fmt.Printf增加输出一个换行符的目的。在调用Printfln的函数的代码中,应按下面的方式调用。


package main


import (

  "tools"

)


func main() {

  tools.Printfln("2+3=%v", 2+3)

}


首先要引用“tools”这个包,然后在代码中用tools.Printfln的方式调用函数。运行这段代码可以看到,使用了tools.Printfln函数后,不需要加入换行符“\n”也可以输出一个换行符。为了调用简单,我们可以在引用tools包时给它一个别名,


package main


import (

  t "tools"

)


func main() {

  t.Printfln("2+3=%v", 2+3)

}

代码 4‑19 用别名引用tools包


代码4‑19中引用tools包时,给了它一个别名:仅一个字母的“t”,这样后面代码中就可以用t.Printfln来调用该函数。不过,要注意t这个字母就不能再用于定义其他的变量或函数名等标识符了。


本系列文章后面的例子中将大量用到tools包中包括Printfln和将来会编写的一些实用函数,该包完整的代码可以在Github网站上https://github.com/topxeq/goexamples/tools处(https://github.com/topxeq/goexamples/blob/master/tools/tools.go)查看到。使用时,将该代码下载放入GOPATH/src目录下的tools子目录即可。

你可能感兴趣的:(X.0 Go语言自己编写工具包(附本系列文章所用的tools包))