Golang中new()和make()两个内置函数的区别是什么

new() 返回指向零值的指针,适用于所有类型;make() 初始化 slice、map、channel 并返回值本身,仅用于这三种引用类型,二者不可混用。

golang中new()和make()两个内置函数的区别是什么

new()make() 都是 Go 语言中的内置函数,但它们的用途和返回值有本质区别,不能混用。

new():为类型分配零值内存并返回指针

new() 用于任何类型,它会:

分配一块足够容纳该类型的内存 将这块内存清零(即设置为该类型的零值) 返回指向这块内存的指针 *T例如:

ptr := new(int)// ptr 是 *int 类型,指向一个值为 0 的 int 变量

new() 常用于需要显式初始化指针的场景,比如构造结构体指针:

type Person struct {    Name string    Age  int}p := new(Person)// 等价于 &Person{},p 指向一个字段都为零值的 Person 实例

make():初始化 slice、map 和 channel

make() 只能用于三种引用类型:slice、map 和 channel。

立即学习“go语言免费学习笔记(深入)”;

它的作用是初始化这些类型的内部结构,使它们可以被正常使用,但不会返回指针,而是返回类型本身。

为 slice 分配底层数组,并设置长度和容量 为 map 创建哈希表结构 为 channel 分配缓冲区和同步结构例如:

slice := make([]int, 5)     // 长度为5,容量为5的切片m := make(map[string]int)   // 可用的 mapch := make(chan int, 10)    // 带缓冲的 channel

注意:make() 返回的是值类型(如 []int、map[string]int),不是指针。

关键区别总结

目标类型不同:new() 可用于任意类型;make() 仅用于 slice、map、channel 返回值不同:new(T) 返回 *T;make(T) 返回 T(T 为三种引用类型之一) 用途不同:new() 分配并零值初始化内存;make() 初始化引用类型的内部结构以便使用

如果对 slice、map 或 channel 使用 new(),只会得到一个指向零值的指针,无法直接使用。比如:

m := new(map[string]int)// m 是 *map[string]int,但 *m 是 nil,不能直接赋值

必须用 make() 来初始化才能使用。

基本上就这些。new 用来分配内存并取指针,make 用来初始化特定引用类型。

以上就是Golang中new()和make()两个内置函数的区别是什么的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1401952.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月15日 18:15:58
下一篇 2025年12月15日 18:16:07

相关推荐

  • 如何在Golang中创建和使用自定义的错误类型

    自定义错误类型通过结构体实现error接口,可携带错误码、时间戳等额外信息,提升错误处理灵活性。 在Go语言中,错误处理是通过返回 error 类型值来实现的。虽然Go内置了 errors.New 和 fmt.Errorf 来创建简单错误,但在实际开发中,我们经常需要更丰富的错误信息,比如错误码、时…

    2025年12月15日
    000
  • reflect.DeepEqual在Golang中是如何工作的

    答案:reflect.DeepEqual通过反射递归比较两个值的类型和字段,适用于结构体、切片、map等复杂类型的深度比较,要求类型完全一致,nil值相等,但函数和不可比较类型无法比较,性能较低且不适用于循环引用。 reflect.DeepEqual 是 Golang 中用于判断两个值是否“深度相等…

    2025年12月15日
    000
  • Golang中值类型和指针类型在JSON序列化和反序列化时的表现

    Go中JSON序列化时值类型与指针类型行为一致,因json.Marshal会自动解引用指针;但nil指针序列化为null,而零值字段使用默认值,如空字符串或0;反序列化时指针可区分字段是否提供,配合omitempty能判断字段是否存在,嵌套指针字段可自动分配内存;因此对需区分“未设置”与“零值”的场…

    2025年12月15日
    000
  • 如何在Golang中引用本地正在开发尚未发布的模块

    使用replace指令或Go Workspaces可引用本地模块。首先在主应用go.mod中通过require声明本地模块路径,再用replace指令将其映射到本地文件系统路径(相对或绝对),随后运行go mod tidy使更改生效;另一种更优方案是使用Go 1.18+的Go Workspaces,…

    2025年12月15日
    000
  • 如何使用第三方库Cobra构建一个更强大的Golang命令行应用

    使用Cobra可快速构建Go命令行应用,它提供命令与子命令结构、标志参数解析、自动帮助和shell补全功能。通过go get安装后,用cobra init初始化项目,生成根命令和主入口。在cmd目录下执行cobra add serve创建子命令,定义Use、Short和Run逻辑,并在init中添加…

    2025年12月15日
    000
  • Golang中如何通过反射判断一个类型是否实现了某个特定接口

    答案:通过reflect.TypeOf((*io.Reader)(nil)).Elem()获取接口类型,再调用reflect.Type.Implements方法判断指定类型是否实现该接口,可封装为通用函数验证任意类型是否满足接口。 在Go语言中,可以通过反射(reflect包)判断一个类型是否实现了…

    2025年12月15日
    000
  • macOS系统下安装Golang并配置环境变量的完整步骤

    答案:安装Golang需下载官方pkg包并配置GOROOT、GOPATH和PATH环境变量。通过编辑~/.zshrc或~/.bash_profile添加export GOROOT=/usr/local/go、export GOPATH=$HOME/go、export PATH=$PATH:$GORO…

    2025年12月15日
    000
  • Golang项目初始化命令go mod init的正确使用场景

    go mod init 的核心作用是为Go项目创建唯一的模块路径,标志着项目进入模块化时代。它用于三种场景:1. 创建新项目时初始化模块;2. 将旧GOPATH项目迁移到Go模块;3. 为缺失go.mod的克隆项目手动创建。模块路径应全局唯一,推荐使用VCS地址如github.com/user/re…

    2025年12月15日
    000
  • 怎样用Golang开发RESTful微服务 使用Gin框架实践

    使用 gin 框架开发 restful 微服务时,应采用分层项目结构,通过路由分组定义接口,利用数据绑定与校验处理请求,结合 service 层封装业务逻辑,并通过中间件扩展功能,最终构建清晰、可维护的高性能服务,完整实践包括模型定义、路由注册、错误处理及测试验证,且应结合数据库实现持久化,以构建生…

    2025年12月15日
    000
  • 如何用Golang处理第三方库的错误 解析错误类型断言与转换技巧

    处理golang中第三方库错误类型的关键在于正确使用类型断言和errors.as。首先,了解error是一个接口,任何实现error()方法的类型均可作为error返回;其次,使用类型断言判断已知具体类型,如if neterr, ok := err.(networkerror); ok { &#82…

    2025年12月15日 好文分享
    000
  • Golang包(package)中标识符首字母大写的含义是什么

    首字母大写标识符对外公开,可被其他包访问;小写则为私有,仅包内可见,Go通过此规则实现访问控制。 在Golang中,包(package)内的标识符(如变量、函数、结构体、方法等)如果首字母大写,表示它是对外公开的,可以被其他包访问。如果首字母小写,则是私有的,仅在定义它的包内部可见。 首字母大写:公…

    2025年12月15日
    000
  • Golang标准库中的包是如何被组织和导入的

    Go标准库按功能层级组织,如fmt用于格式化输出,net/http处理HTTP,遵循“约定优于配置”,通过$GOROOT/src自动解析导入路径,提升可读性与维护性,推荐先查标准库、避免未使用导入,并利用首字母控制可见性。 Go语言标准库中的包组织得相当直观,它们通常按照功能领域进行划分,形成一个逻…

    2025年12月15日
    000
  • 如何避免在Golang并发编程中因共享指针引发数据竞争

    避免数据竞争的关键是控制共享指针访问。应优先传递值副本或使用不可变数据,避免多goroutine直接共享指针;若需修改共享数据,用sync.Mutex保护所有读写操作;推荐通过通道传递指针,实现所有权转移,确保独占访问;仅当需原子读写指针本身时,使用sync/atomic的LoadPointer和S…

    2025年12月15日
    000
  • Golang的GOPATH和GOROOT究竟有什么区别 如何正确设置

    GOPATH是Go项目的工作区,存放源码、依赖和编译文件;GOROOT是Go安装目录,包含核心工具和标准库。两者需正确配置,GOROOT通常自动设置,GOPATH推荐设为用户主目录下的go文件夹,并将$GOPATH/bin加入PATH。Go Modules出现后,GOPATH在依赖管理中的作用减弱,…

    2025年12月15日
    000
  • 一个Golang目录中为什么只能存在一个包

    一个目录一个包的规则通过强制文件系统与逻辑单元一致,消除歧义,提升可读性与可维护性,简化编译和依赖解析,促进高内聚低耦合设计,避免循环依赖,支持清晰的模块划分和团队协作。 Go语言中一个目录只能包含一个包,这并非偶然,而是其核心设计哲学——简洁与明确——的直接体现。这种强制性的结构,旨在消除歧义,简…

    2025年12月15日
    000
  • Golang如何正确处理context超时错误 区分deadline与cancel场景

    在golang中,正确处理context超时错误的关键在于区分context.deadlineexceeded和context.canceled。1. context.deadlineexceeded表示设定的截止时间已到,任务未完成;2. context.canceled表示context被主动取…

    2025年12月15日 好文分享
    000
  • Golang文件读取方法 os和ioutil包对比

    Go 1.16后ioutil被弃用,os包成文件读取首选。os.Open支持流式读取,适合大文件;os.ReadFile替代ioutil.ReadFile,简洁读取小文件;io.ReadAll处理任意io.Reader。推荐使用os包进行文件操作,结合io包工具高效处理数据流,避免内存溢出,提升代码…

    2025年12月15日
    000
  • Golang中var和:=两种变量声明方式有何区别

    var可用于函数内外,支持显式类型声明与仅声明不赋值;2. :=仅用于函数内部,自动推导类型且必须初始化;3. 区别在于作用域、类型指定、初始化要求和简洁性;4. 建议包级别用var,函数内简洁初始化用:=,统一风格提升可读性。 在Golang中,var 和 := 都用于声明变量,但它们的使用场景和…

    2025年12月15日
    000
  • Golang错误处理优化 减少错误检查开销技巧

    通过预定义错误、延迟检查、defer-recover和适度包装,减少Go中高频路径的错误处理开销,提升性能与可读性。 在Go语言开发中,错误处理是日常编码的重要部分。虽然 if err != nil 模式清晰直接,但在高频路径或性能敏感场景下,频繁的错误检查可能带来一定开销。通过合理设计和编码技巧,…

    2025年12月15日
    000
  • Golang中如何通过反射获取一个类型的包路径(PkgPath)

    答案:通过reflect.Type的PkgPath()方法可获取类型所在包的导入路径,如自定义类型返回包路径,内建或未命名类型返回空字符串。示例中MyStruct输出”main”,time.Time输出”time”,int和[]string输出空;常用…

    2025年12月15日
    000

发表回复

登录后才能评论
关注微信