会崩溃,且是运行时 panic;局部变量栈上分配,函数返回后地址不可访问,编译器仅能静态捕获部分情况,间接取地址可能延迟至运行时崩溃。
会,而且是运行时 panic。Go 编译器对 return &localVar 有静态检查,但并非所有情况都能捕获——比如在闭包、循环内取地址,或通过中间函数转发时,可能绕过检查,最终触发 invalid memory address or nil pointer dereference。
cannot take the address of …
&s[0]、&x.field),可能仅在运行时崩溃核心判断依据是:是否需要「可变性共享」或「避免拷贝开销」。不是“习惯性加 *”,而是明确设计意图。
*T 减少内存复制(*bytes.Buffer).Write),返回 *T 才能调用这些方法nil 表示“未初始化”或“可选缺失”语义(如 func NewConfig() *Config)二者都分配堆内存并返回 *T,但语义和可读性不同:&T{} 更常用、更清晰;new(T) 仅适用于零值初始化且无字段赋值场景。
&T{} 显式构造,支持字段初始化(如 &User{Name: "Alice"}),推荐用于绝大多数情况new(T) 总是返回零值指针,无法设置字段,等价于 &T{} 但更隐晦,仅在泛型或反射等底层场景偶见&struct{}{} 是合法的,但 new(struct{}) 也合法——不过空结构体指针几乎无意义,慎用func CreateUser(name string) *User {
return &User{Name: name, CreatedAt: time.Now()} // 清晰、可控
}
func ZeroUser() *User {
return new(User) // 不推荐:无法设字段,不如直接写 &User{}
}
返回 nil 指针

FindUser() 可返回 nil,MustGetUser() 则 panic)if x == nil { return nil } 这类冗余判断——除非你是在封装底层可能返回 nil 的逻辑*[]int),这违背 Go 习惯且增加复杂度最容易被忽略的是:指针字段的深层嵌套判空。比如 u.Profile.Address.Street,中间任一环节为 nil 都会 panic,不能只检查顶层指针。