package main
import "fmt"
// 执行下面的代码会引发panic,为什么呢? 在Go语言中对于引用类型的变量,
// 我们在使用的时候不仅要声明它,还要为它分配内存空间,否则我们的值就没办法存储。
// 而对于值类型的声明不需要分配内存空间,是因为它们在声明的时候已经默认分配好了内存空间。
// 要分配内存,就引出来今天的new和make。 Go语言中new和make是内建的两个函数,主要用来分配内存
func main() {
var a *int
*a = 100
fmt.Println(*a)
}
//会有下面的报错
//panic: runtime error: invalid memory address or nil pointer dereference
//[signal SIGSEGV: segmentation violation code=0x1 addr=0x0 pc=0x10a3083]
// 下面这样就好了,加一行 a = new(int)
func main() {
var a *int
a = new(int)
*a = 100
fmt.Println(*a)
}
关于new函数:
func new(Type) *Type
1.Type表示类型,new函数只接受一个参数,这个参数是一个类型
2.*Type表示类型指针,new函数返回一个指向该类型内存地址的指针。
make也是用于内存分配的,区别于new,它只用于slice、map以及chan的内存创建,而且它返回的类型就是这三个类型本身,
而不是他们的指针类型,因为这三种类型就是引用类型,所以就没有必要返回他们的指针了。make函数的函数签名如下:
func make(t Type, size ...IntegerType) Type
func main() {
var mapa map[string]int
mapa = make(map[string]int) // map 必须初始化,不然会创建nil map
// panic: assignment to entry in nil map
mapa ["zhangsan"] = 18
mapa ["lisi"] = 20
for k := range mapa {
fmt.Println(k)
}
}
new 和 make的区别
1.二者都是用来做内存分配的。
2.make只用于slice、map以及channel的初始化,返回的还是这三个引用类型本身;
3.而new用于类型的内存分配,并且内存对应的值为类型零值,返回的是指向类型的指针。