一边学习一边整理老师的课程内容及试验笔记,并与大家分享,侵权即删,谢谢支持!
这个包提供了一些类型声明、变量和常量声明,还有一些便利函数,这个包不需要导入,这些变量和函数就可以直接使用。
常用函数append
func append(slice []Type, elems ...Type) []Type
slice = append(slice, elem1, elem2) //直接在slice后面添加单个元素,添加元素类型可以和slice相同,也可以不同
slice = append(slice, anotherSlice) //直接将另外一个slice添加到slice后面,但其本质还是讲anotherSlice中的元素一个一个添加到slice中,和第一种方式类似
实例
package main
import (
"fmt"
)
func main() {
s1 := []int{1, 2, 3}
i := append(s1, 4)
fmt.Printf("i: %v\n", i)
s2 := []int{7, 8, 9}
i2 := append(s1, s2...)
fmt.Printf("i2: %v\n", i2)
}
运行结果
[Running] go run "/Users/guoliang/SynologyDrive/软件开发/go/golang入门到项目实战/goproject/360duote.com/pro01/test.go"
i: [1 2 3 4]
i2: [1 2 3 7 8 9]
len
返回,数组、切片、字符串、通道的长度
实例
import (
"fmt"
)
func main() {
s1 := "hello world"
i := len(s1)
fmt.Printf("i: %v\n", i)
s2 := []int{1, 2, 3}
fmt.Printf("len(s2): %v\n", len(s2))
}
运行结果
[Running] go run "/Users/guoliang/SynologyDrive/软件开发/go/golang入门到项目实战/goproject/360duote.com/pro01/test.go"
i: 11
len(s2): 3
print、println
打印输出到控制台。
实例
package main
import (
"fmt"
)
func main() {
name := "tom"
age := 20
print(name, " ", age, "\n")
fmt.Println("---------")
println(name, " ", age)
}
运行结果
[Running] go run "/Users/guoliang/SynologyDrive/软件开发/go/golang入门到项目实战/goproject/360duote.com/pro01/tempCodeRunnerFile.go"
tom 20
tom 20
---------
panic
抛出一个panic异常
实例
package main
import (
"fmt"
)
func main() {
defer fmt.Println("panic 异常后执行...")
panic("panic 错误...")
fmt.Println("end...")
}
运行结果
[Running] go run "/Users/guoliang/SynologyDrive/软件开发/go/golang入门到项目实战/goproject/360duote.com/pro01/test.go"
panic 异常后执行...
panic: panic 错误...
goroutine 1 [running]:
main.main()
/Users/guoliang/SynologyDrive/软件开发/go/golang入门到项目实战/goproject/360duote.com/pro01/test.go:9 +0x73
exit status 2
new和make
new和make区别:
- make只能用来分配及初始化类型为slice,map,chan的数据;new可以分配任意类型的数据
- new分配返回的是指针,即类型*T;make返回引用,即T;
- new分配的空间被清零,make分配后,会进行初始化。
实例
package main
import (
"fmt"
)
func testNew() {
b := new(bool)
fmt.Println(*b)
i := new(int)
fmt.Println(*i)
s := new(string)
fmt.Println(*s)
}
func main() {
testNew()
}
运行结果
[Running] go run "/Users/guoliang/SynologyDrive/软件开发/go/golang入门到项目实战/goproject/360duote.com/pro01/test.go"
false
0
make
内建函数make(T, args)与new(T)的用途不一样。它只用来创建slice、map和channel,并且返回一个初始化的(而不是置零),类型为T的值(而不是*T)。之所以有所不同,是因为这三个类型的背后引用了使用前必须初始化的数据结构。例如,slice是一个三元描述符,包含一个指向数据(在数组中)的指针,长度,以及容量,在这些项被初始化之前,slice都是nil的。对于slice,map和channel,make初始化这些内部数据结构,并准备好可用的值。
make([]int, 10 , 100)
分配一个有100个int的数组,然后创建一个长度为10,容量为100的slice结构,该slice引用包含前10个元素的数组。对应的,new([]int)返回一个指向新分配的,被置零的slice结构体的指针,即指向值为nil的slice的指针。
package main
import "fmt"
func main() {
var p *[]int = new([]int) // allocates slice structure; *p == ni; rarely useful
var v []int = make([]int, 10) // the slice v now refers to a new array of 100 ints
fmt.Printf("p: %v\n", p)
fmt.Printf("v: %v\n", v)
// Unnecessarily complex: 这种做法实在是很蛋疼
var p1 *[]int = new([]int)
*p1 = make([]int, 5, 10)
// Idiomatic: 习惯的做法
v1 := make([]int, 10)
fmt.Printf("p1: %v\n", p1)
fmt.Printf("v1: %v\n", v1)
}
运行结果
[Running] go run "/Users/guoliang/SynologyDrive/软件开发/go/golang入门到项目实战/goproject/360duote.com/pro01/test.go"
p: &[]
v: [0 0 0 0 0 0 0 0 0 0]
p1: &[0 0 0 0 0]
v1: [0 0 0 0 0 0 0 0 0 0]