go语言中new和make的区别

我们以一个new一个map和make一个map为例来讲解下:

make map:

Go 复制代码
package main

import (
	"fmt"
)

func main() {

	umap := make(map[string]string)
	fmt.Println(umap)

}

找到map源码,找到makemap方法

可以看到,执行make map的时候,底层会调用makemap方法(slice和chan也有各自的make方法)

也就是说,make是用来初始化go中map、slice、chan的特有方法,它既会给对象分配内存,也会初始化对象。但是new不会,new只会单纯给对象分配内存。

再举个例子:

Go 复制代码
package main

import "fmt"

type MyMap struct {
	SingleMap map[string]string
	Uname     string
	Uage      int
}

func main() {
	m := *new(MyMap)
	fmt.Println("uname:", m.Uage)
	m.SingleMap["uname"] = "lyl"
	fmt.Println(m)
}

我自定义了一个MyMap,通过new初始化后,往这个map的SingleMap里添加元素的时候报错了,因为SingleMap还没有初始化。

相关推荐
程序员清风4 分钟前
滴滴二面:MySQL执行计划中,Key有值,还是很慢怎么办?
java·后端·面试
huohaiyu17 分钟前
synchronized (Java)
java·开发语言·安全·synchronized
_OP_CHEN24 分钟前
C++基础:(九)string类的使用与模拟实现
开发语言·c++·stl·string·string类·c++容器·stl模拟实现
熊小猿25 分钟前
Spring Boot 的 7 大核心优势
java·spring boot·后端
shepherd11137 分钟前
JDK 8钉子户进阶指南:十年坚守,终迎Java 21升级盛宴!
java·后端·面试
蓝天智能38 分钟前
QT MVC中View的特点及使用注意事项
开发语言·qt·mvc
yeyong41 分钟前
如何让 docker镜像使用系统时间,而不是utc
后端
Penge66644 分钟前
分布式与集群:从概念到跨机房部署
后端
凉城a1 小时前
经常看到的IPv4、IPv6到底是什么?
前端·后端·tcp/ip
蓝宝石Kaze1 小时前
Go + SNS + SQS + Localstack 实现消息队列
后端·aws