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还没有初始化。

相关推荐
IT_陈寒1 天前
Python开发者必知的5大性能陷阱:90%的人都踩过的坑!
前端·人工智能·后端
流浪克拉玛依1 天前
Go Web 服务限流器实战:从原理到压测验证 --使用 Gin 框架 + Uber Ratelimit / 官方限流器,并通过 Vegeta 进行性能剖析
后端
孟沐1 天前
保姆级教程:手写三层架构 vs MyBatis-Plus
后端
星浩AI1 天前
让模型自己写 Skills——从素材到自动生成工作流
人工智能·后端·agent
华仔啊1 天前
为啥不用 MP 的 saveOrUpdateBatch?MySQL 一条 SQL 批量增改才是最优解
java·后端
武子康1 天前
大数据-242 离线数仓 - DataX 实战:MySQL 全量/增量导入 HDFS + Hive 分区(离线数仓 ODS
大数据·后端·apache hive
砍材农夫1 天前
TCP和UDP区别
后端
千寻girling1 天前
一份不可多得的 《 Django 》 零基础入门教程
后端·python·面试
千寻girling1 天前
Python 是用来做 AI 人工智能 的 , 不适合开发 Web 网站 | 《Web框架》
人工智能·后端·算法
贾铭1 天前
如何实现一个网页版的剪映(三)使用fabric.js绘制时间轴
前端·后端