1、为什么有包这个概念?
1)开发中,往往要在不同的文件中调用其他文件的函数
2)Go代码最小粒度单位是”包”
3)go的每一个文件都属于一个包,通过package管理
4)go以包的形式管理文件和项目目录结构
5)包的命名不要和保留名称重复
6)编译可执行文件,必须包含package main,入口函数为main()
2、Go包的作用
1)区分同名的函数、变量等标识符
2)管理项目程序文件
3)控制函数、变量访问作用域
4)Go包中的变量,以首字母大小写决定是否可以被导出(public),如Foo可以被导出,foo则不(internal)
3、Go包目录结构
1 gostudy 2 | 3 +--- bin // go install 安装目录。 4 | | 5 | +--- hello //可执行命令hello 6 | 7 +--- pkg // go build 生成静态库 (.a) 存放目录。 8 | | 9 | +--- darwin_amd64 10 | | 11 | +--- lib.a 12 | | 13 | +--- lib 14 | | 15 | +--- sublib.a 16 | 17 +--- src // 项目源码目录。 18 | | 19 | +---golearn 20 | 21 +--- learn 22 | | 23 | +--- main.go
可以在GOPATH环境变量列表中添加多个工作空间,但不能和GOROOT相同。通常go get使用第一个工作空间保存下载的第三方库.
4、Go包的导入
导入包:使用包成员之前,必须先用import关键字导入,但是不能形成导入循环
import "相对目录/包主文件名"
在导入时,可指定包成员访问方式。比如对包重命名,以避免同名冲突。
import用法:
1 import "fmt" 最常用导入系统包 2 import "./test" 导入当前目录的包(相对路径) 3 import "gostudy/model 加载gopath/src/gostudy/model模块(绝对路径) 4 import f "fmt" 导入fmt,且给与别名f,可以通过f. 方式调用函数 5 import . "fmt" 将fmt启用别名".",这样就可以直接使用其内容,而不用再添加fmt.Println() 6 import _ "fmt" 表示不使用该包,而是只是使用该包的init函数,而不能够使用该包的其他函数。
语法使用:
1 声明包 2 package 包名 3 4 引入包 5 import '包的路径'
5、Go格式化fmt包
golang的fmt包实现了格式化I/O函数,类似于python的{}.format()
普通占位符
1 占位符 说明 举例 输出 2 %v 相应值的默认格式。 Printf("%v", people) {zhangsan}, 3 %+v 打印结构体时,会添加字段名 Printf("%+v", people) {Name:zhangsan} 4 %#v 相应值的Go语法表示 Printf("%#v", people) main.Human{Name:"zhangsan"} 5 %T 相应值的类型的Go语法表示 Printf("%T", people) main.Human 6 %% 字面上的百分号,并非值的占位符 Printf("%%") %
布尔占位符
1 占位符 说明 举例 输出 2 %t true 或 false。 Printf("%t", true) true
整数占位符
1 占位符 说明 举例 输出 2 %b 二进制表示 Printf("%b", 5) 101 3 %c 相应Unicode码点所表示的字符 Printf("%c", 0x4E2D) 中 4 %d 十进制表示 Printf("%d", 0x12) 18 5 %o 八进制表示 Printf("%d", 10) 12 6 %q 单引号围绕的字符字面值,由Go语法安全地转义 Printf("%q", 0x4E2D) '中' 7 %x 十六进制表示,字母形式为小写 a-f Printf("%x", 13) d 8 %X 十六进制表示,字母形式为大写 A-F Printf("%x", 13) D 9 %U Unicode格式:U+1234,等同于 "U+%04X" Printf("%U", 0x4E2D) U+4E2D
浮点数和复数的组成部分(实部和虚部)
1 占位符 说明 举例 输出 2 %b 无小数部分的,指数为二的幂的科学计数法, 3 与 strconv.FormatFloat 的 'b' 转换格式一致。例如 -123456p-78 4 %e 科学计数法,例如 -1234.456e+78 Printf("%e", 10.2) 1.020000e+01 5 %E 科学计数法,例如 -1234.456E+78 Printf("%e", 10.2) 1.020000E+01 6 %f 有小数点而无指数,例如 123.456 Printf("%f", 10.2) 10.200000 7 %g 根据情况选择 %e 或 %f 以产生更紧凑的(无末尾的0)输出 Printf("%g", 10.20) 10.2 8 %G 根据情况选择 %E 或 %f 以产生更紧凑的(无末尾的0)输出 Printf("%G", 10.20+2i) (10.2+2i)
字符串与字节切片
1 占位符 说明 举例 输出 2 %s 输出字符串表示(string类型或[]byte) Printf("%s", []byte("Go语言")) Go语言 3 %q 双引号围绕的字符串,由Go语法安全地转义 Printf("%q", "Go语言") "Go语言" 4 %x 十六进制,小写字母,每字节两个字符 Printf("%x", "golang") 676f6c616e67 5 %X 十六进制,大写字母,每字节两个字符 Printf("%X", "golang") 676F6C616E67
指针
1 占位符 说明 举例 输出 2 %p 十六进制表示,前缀 0x Printf("%p", &people) 0x4f57f0
其他标记
1 占位符 说明 举例 输出 2 + 总打印数值的正负号;对于%q(%+q)保证只输出ASCII编码的字符。 3 Printf("%+q", "中文") "u4e2du6587" 4 - 在右侧而非左侧填充空格(左对齐该区域) 5 # 备用格式:为八进制添加前导 0(%#o) Printf("%#U", '中') U+4E2D 6 为十六进制添加前导 0x(%#x)或 0X(%#X),为 %p(%#p)去掉前导 0x; 7 如果可能的话,%q(%#q)会打印原始 (即反引号围绕的)字符串; 8 如果是可打印字符,%U(%#U)会写出该字符的 9 Unicode 编码形式(如字符 x 会被打印成 U+0078 'x')。 10 ' ' (空格)为数值中省略的正负号留出空白(% d); 11 以十六进制(% x, % X)打印字符串或切片时,在字节之间用空格隔开 12 0 填充前导的0而非空格;对于数字,这会将填充移到正负号之后