

新闻资讯
行业动态new 返回 *T 类型的零值指针,仅分配并清零内存,不初始化逻辑或创建可直接使用的 slice/map/channel;make 才用于构造可立即使用的引用类型。
Go 的 new 函数返回的是指向零值的指针,它不初始化结构体字段以外的逻辑,也不创建可直接使用的 slice/map/channel —— 这是和 make 的根本区别。
new 总是返回 *T,且值一定是零值?new(T) 做且只做一件事:分配一块足够存下类型 T 的内存,把这块内存清零(即填入 T 的零值),然后返回指向它的 *T。它不管类型是否可“构造”,也不调用任何方法。
i := new(int) → *i 是 0
p := new(Person) → *p 是 {Name: "", Age: 0},不是 nil,但所有字段都是零值s := new([]int) → *s 是一个 nil slice(注意:不是空 slice []int{})nil 值的指针,*m 是 nil,不能直接 map[key] = val,会 panicnew 和 make 到底该用哪个?看你要什么:
new
make,new 给不了你这个能力new,直接用字面量:p := &Person{Name: "Alice", Age: 30}
func example() {
// ✅ 正确:new 返回 *[]int,
但 *s 是 nil,不能 append
s := new([]int)
// append(*s, 1) // panic: append to nil slice
// ✅ 正确:make 返回可操作的 slice
s2 := make([]int, 0)
s2 = append(s2, 1) // OK
// ✅ new 适合快速拿到一个零值指针,比如作为函数参数占位
var p *int = new(int) // 等价于 p := new(int)
fmt.Println(*p) // 0
}
new([]int) 能当空切片用这是最常踩的坑。错误现象:panic: runtime error: invalid memory address or nil pointer dereference,尤其在你对 *s 做 len、append 或遍历时发生。
立即学习“go语言免费学习笔记(深入)”;
new([]int) 返回 *[]int,其解引用 *s 是 nil slicemake([]int, 0) 返回 []int,本身就是一个长度为 0、底层数组已分配的合法 slicemake 再取地址:s := make([]int, 5); ps := &s
new?现实中的合理场景它不是高频函数,但在特定上下文很干净:
cfg := new(Config),再逐个字段赋值sync.Pool 配合时,pool.Get() 常返回 interface{},用 new(T) 初始化池中对象是惯用法nil 指针用于断言接收者是否为指针类型var t T; return &t 的啰嗦写法,return new(T) 更直白真正容易被忽略的一点:Go 编译器对 new 的逃逸分析非常保守——它几乎总是让 new 分配的对象逃逸到堆上,因为返回的就是指针。但这不是你需要操心的事,只要记住:new 的语义就是「给我一个堆上的零值指针」,就够了。