今天在聊make和new函数之前,咱们先来看一种现象 当然如果你对golang的指针还不是很了解,可以先看看这篇文章,以做到无缝连接
👇👇👇👇👇👇👇👇👇👇👇👇👇👇👇👇👇
var a int
a = 1
fmt.Println(a)
//返回结果
//1
这个例子很简单,咱们定义了一个int类型的变量,然后赋值直接输出,这个没什么好疑问的,但是咱们把这个例子改一下
var p *int
*p = 10
fmt.Println(*p)
请问上面代码会输出什么?不出意外会输出10对不对,但是咱们运行之后,命令行却输出
panic: runtime error: invalid memory address or nil pointer dereference
[signal SIGSEGV: segmentation violation code=0x2 addr=0x0 pc=0x10428df44]
goroutine 1 [running]:
main.main()
这是为什么呢?
因为我们在var p *int,只是把p变量定义为了指针类型,p的默认值为nil,「并没有在内存上分配对应的空间」,既然没有空间,那给p变量赋值自然就会报错,当然p任然是占空间的,只不过p的值为nil
var p *int = new(int)
*p = 10
fmt.Println(*p)
//输出结果
//10
结果就可以正常输出,为什么加个new就可以正常输出呢?想要回答这个问题,首先你得知道new函数做了什么。
make和new都是用来内存分配的方法,简单的说,new只分配内存,
func make(t Type, size ...IntegerType) Type
func new(Type) *Type
完