For-learning-Go-Tutorial
Go语言各种值类型,包括字符串、整数、浮点数、布尔值等。下面是一些基本示例。
Go语言最主要的特性:
- 自动垃圾回收
- 更丰富的内置类型
- 函数多返回值
- 错误处理
- 匿名函数和闭包
- 类型和接口
- 并发编程
- 反射
- 语言交互性
Go语言案例总结
最近一直在写一部针对初入门Golang开发人员的书,我觉得最好的状态就是学习了基础之后,练习,然后做项目中不断的提高!
GO 例子目录:
- Go 数组
- Go map
- Go 函数定义
- Go 方法
- Go 结构体
- Go 闭包函数
- Go Defer函数
- Go 接口
- Go Base64编码
- Go 状态协程
- Go Panic
- Go 散列函数
- Go 工作池
- Go 进程触发
- Go 时间戳
- Go 时间格式化和解析
- Go 通道缓冲
- Go IO
- Go 压缩
Go数组
- 数组是一个具有相同数据类型的元素组成的固定长度的有序集合。
- 在Go语言中,数组是值类型,长度是类型的组成部分,也就是说”[10]int”和“[20]int”是完全不同的两种数组类型。
- 同类型的两个数组支持”==”和”!=”比较,但是不能比较大小。
- 数组作为参数时,函数内部不改变数组内部的值,除非是传入数组的指针。
- 数组的指针:*[2,3,4]int
- 指针数组:[3]*int
package main
import "fmt"
func main() {
// 这里我们创建了一个具有5个元素的整型数组
// 元素的数据类型和数组长度都是数组的一部分
// 默认情况下,数组元素都是零值
// 对于整数,零值就是0
var a [5]int
fmt.Println("emp:", a)
// 我们可以使用索引来设置数组元素的值,就像这样
// "array[index] = value" 或者使用索引来获取元素值,
// 就像这样"array[index]"
a[4] = 100
fmt.Println("set:", a)
fmt.Println("get:", a[4])
// 内置的len函数返回数组的长度
fmt.Println("len:", len(a))
// 这种方法可以同时定义和初始化一个数组
b := [5]int{1, 2, 3, 4, 5}
fmt.Println("dcl:", b)
// 数组都是一维的,但是你可以把数组的元素定义为一个数组
// 来获取多维数组结构
var twoD [2][3]int
for i := 0; i < 2; i++ {
for j := 0; j < 3; j++ {
twoD[i][j] = i + j
}
}
fmt.Println("2d: ", twoD)
}
输出结果为:
emp: [0 0 0 0 0]
set: [0 0 0 0 100]
get: 100
len: 5
dcl: [1 2 3 4 5]
2d: [[0 1 2] [1 2 3]]
拥有固定长度是数组的一个特点,但是这个特点有时候会带来很多不便,尤其在一个集合元素个数不固定的情况下。这个时候我们更多地使用切片。
map
map是Go语言内置的关联数据类型。因为数组是索引对应数组元素,而字典是键对应值。
package main
import "fmt"
func main() {
// 创建一个字典可以使用内置函数make
// "make(map[键类型]值类型)"
m := make(map[string]int)
// 使用经典的"name[key]=value"来为键设置值
m["k1"] = 9
m["k2"] = 22
// 用Println输出字典,会输出所有的键值对
fmt.Println("map:", m)
// 获取一个键的值 "name[key]".
v1 := m["k1"]
fmt.Println("v1: ", v1)
// 内置函数返回字典的元素个数
fmt.Println("len:", len(m))
// 内置函数delete从字典删除一个键对应的值
delete(m, "k2")
fmt.Println("map:", m)
// 根据键来获取值有一个可选的返回值,这个返回值表示字典中是否
// 存在该键,如果存在为true,返回对应值,否则为false,返回零值
// 有的时候需要根据这个返回值来区分返回结果到底是存在的值还是零值
// 比如字典不存在键x对应的整型值,返回零值就是0,但是恰好字典中有
// 键y对应的值为0,这个时候需要那个可选返回值来判断是否零值。
_, ok := m["k2"]
fmt.Println("ok:", ok)
// 可以用 ":=" 同时定义和初始化一个字典
n := map[string]int{"foo": 1, "bar": 2}
fmt.Println("map:", n)
}
输出结果为:
map: map[k1:9 k2:22]
v1: 9
len: 2
map: map[k1:9]
ok: false
map: map[foo:1 bar:2]
Go函数定义
函数是Go语言的重要内容。
package main
import "fmt"
// 这个函数计算两个int型输入数据的和,并返回int型的和
func plus(a int, b int) int {
// Go需要使用return语句显式地返回值
return a + b
}
func main() {
// 函数的调用方式很简单
// "名称(参数列表)"
res := plus(1, 2)
fmt.Println("1+2 =", res)
}
输出结果为:
1+2 = 3
Go方法
通常的函数定义叫做函数,定义在结构体上面的函数叫做该结构体的方法。 从某种意义上说,方法是函数的“语法糖”。当函数与某个特定的类型绑定,那么它就是一个方法。也证因为如此,我们可以将方法“还原”成函数。
package main
import "fmt"
type rect struct {
width, height int
}
// 这个area方法有一个限定类型*rect,
// 表示这个函数是定义在rect结构体上的方法
func (r *rect) area() int {
return r.width * r.height
}
// 方法的定义限定类型可以为结构体类型
// 也可以是结构体指针类型
// 区别在于如果限定类型是结构体指针类型
// 那么在该方法内部可以修改结构体成员信息
func (r rect) perim() int {
return 2*r.width + 2*r.height
}
func main() {
r := rect{width: 10, height: 5}
// 调用方法
fmt.Println("area: ", r.area())
fmt.Println("perim:", r.perim())
// Go语言会自动识别方法调用的参数是结构体变量还是
// 结构体指针,如果你要修改结构体内部成员值,那么使用
// 结构体指针作为函数限定类型,也就是说参数若是结构体
//变量,仅仅会发生值拷贝。
rp := &r
fmt.Println("area: ", rp.area())
fmt.Println("perim:", rp.perim())
}
输出结果为:
area: 50
perim: 30
area: 50
perim: 30