Golang面试make和new的用法(golang 面试题(从基础到高级))

注意:免费节点订阅链接已更新至 2025-12-16点击查看详情

在golang中,make和new都分配内存,但是它们之间仍然存在一些差异。只有了解它们之间的差异,才能在适当的场合使用它们。

简而言之,new只是分配内存,而不初始化内存;make分配并初始化内存。所谓的初始化就是给一个类型赋一个初始值,例如,字符为空,整数为0,逻辑值为false。

从Golang的官方文档的builtin(内置的软件包)中可以找到,make和new的用法。

new的使用介绍:

我们先来看看new的定义

// The new built-in function allocates memory. The first argument is a type, // not a value, and the value returned is a pointer to a newly // allocated zero value of that type. //内建函数new分配内存。其第一个实参为类型,而非值。其返回值为指向该类型的新分配的零值的指针。 func new(Type) *Type

可以看出,它的参数是一个类型,返回值是指向该类型的内存地址的指针,并且分配的内存将被设置为零,即该类型的零值,即字符为空,整数为0,逻辑值为false

看一些例子

type P struct { 		Name string 		Age  int 	} 	var a *[2]int 	var s *string 	var b *bool 	var i *int 	var ps *P  	a = new([2]int) 	s = new(string) 	b = new(bool) 	i = new(int) 	ps = new(P) //structure  	fmt.Println(a, " ", *a) 	fmt.Println(s, " ", *s) 	fmt.Println(b, " ", *b) 	fmt.Println(i, " ", *i) 	fmt.Println(ps, " ", *ps)

输出如下:

&[0 0]   [0 0] 0xc0000821e0    0xc0000a409a   false 0xc0000a40b0   0 &{ 0}   { 0}

上面基础类型,我们看一下slice, map and channel类型是如何操作的:

		//map 操作     var mp *map[string]string     mp = new(map[string]string) 		//注释掉下面的行,new map 返回为nil,直接使用会panic     //*mp = make(map[string]string) // if this line is omitted, it will pan "Pan: assignment to entry in nil map"“     (*mp)["name"] = "lc"     fmt.Println((*mp)["name"])         // slice 操作     var ms *[]string     ms = new([]string) 	  // 注释掉下面的行访问的时候会下标超出范围     //*ms = make([]string,5) // if this line is deleted, it will "panic: runtime error: index out of range"     (*ms)[0] = "lc"     fmt.Println((*ms)[0]) 

从上面可以看出,silce,map,channel和其他类型是引用类型。当引用类型初始化为nil时,不能直接分配nil,也不能使用new来分配内存,还需要使用make来进行分配。

make的使用介绍:

我们看一下make的定义

/ /The make built-in function allocates and initializes an object of type // slice, map, or chan (only). Like new, the first argument is a type, not a // value. Unlike new, make's return type is the same as the type of its // argument, not a pointer to it. The specification of the result depends on // the type: //  Slice: The size specifies the length. The capacity of the slice is //  equal to its length. A second integer argument may be provided to //  specify a different capacity; it must be no smaller than the //  length. For example, make([]int, 0, 10) allocates an underlying array //  of size 10 and returns a slice of length 0 and capacity 10 that is //  backed by this underlying array. //  Map: An empty map is allocated with enough space to hold the //  specified number of elements. The size may be omitted, in which case //  a small starting size is allocated. //  Channel: The channel's buffer is initialized with the specified //  buffer capacity. If zero, or the size is omitted, the channel is //  unbuffered. //切片:size指定了其长度。该切片的容量等于其长度。切片支持第二个整数实参可用来指定不同的容量; 它必须不小于其长度,因此 make([]int, 0, 10) 会分配一个长度为0,容量为10的切片。 //映射:初始分配的创建取决于size,但产生的映射长度为0。size可以省略,这种情况下就会分配一个小的起始大小。 //通道:通道的缓存根据指定的缓存容量初始化。若 size为零或被省略,该信道即为无缓存的。 func make(t Type, size ...IntegerType) Type

可以看出,它返回的是类型本身而不是指针类型,因为make只能为slice,map,channel等初始化内存,并且它们返回引用类型,因此不必返回指针

让我们看一些make的例子:

    mm :=make(map[string]string)     mm["name"] = "lc"     fmt.Println(mm["name"])      mss :=make([]int,2)     mss[0] = 100     fmt.Println(mss[0])      ch :=make(chan int,1)     ch <-100      fmt.Println(<-ch)

总结:

make仅用于分配和初始化slice,map和chan类型的数据。new可以分配任何类型的数据
。new分配返回一个指针,即Type * Type。make返回一个引用,该引用为Type
由make分配的空间之后,清除并初始化由new分配的空间。

全面解析Shadowrocket在线安装闪退:原因剖析与终极解决方案

引言:当科技便利遭遇"闪退"尴尬

在数字时代,翻墙工具已成为连接世界的数字桥梁,而Shadowrocket凭借其简洁界面和强大功能,长期占据iOS代理工具榜首。但无数用户在欣喜下载后,却遭遇了"点击即闪退"的魔咒——这就像拿到一把万能钥匙,却发现锁孔被神秘力量封印。本文将深入挖掘闪退背后的技术真相,提供一套从预防到修复的完整方案,让您的跨境网络之旅重归顺畅。

第一章 认识Shadowrocket:不只是个代理工具

作为iOS平台最负盛名的代理客户端,Shadowrocket的核心价值在于其智能路由和协议支持。它支持SS/SSR/Vmess等多种协议,能实现应用级代理分流,这种技术复杂性也埋下了潜在兼容性问题的种子。最新统计显示,约23%的用户首次安装时会遭遇闪退,其中70%可通过系统更新解决——这暗示着软件与系统环境的微妙关系。

第二章 闪退现象全息扫描

2.1 典型症状诊断

  • 启动闪退:应用图标刚出现就消失,如同被系统"秒拒"
  • 幽灵进程:后台任务列表中的神秘失踪案
  • 加载闪退:进度条走到一半突然"溶化"在屏幕上

2.2 五大核心诱因深度解析

  1. 系统版本滞后:iOS的沙盒机制会主动终止不兼容进程
  2. 内存博弈:当可用空间低于1GB时,系统开始"清理门户"
  3. 网络握手失败:证书验证过程中的毫秒级延迟都可能触发保护机制
  4. 配置冲突:一个错误的端口号就像配错的钥匙齿痕
  5. 签名异常:企业证书被吊销导致的"突然死亡"

第三章 九大修复方案实战手册

3.1 系统升级疗法(解决85%基础问题)

操作路径:设置→通用→软件更新→下载并安装
技术点评:iOS每个大版本都包含数百个API调整,保持更新就是保持兼容

3.2 彻底重装术(清除深层缓存)

进阶步骤:
1. 长按图标→删除应用
2. 重启设备(关键步骤!)
3. App Store重新下载
注意:使用相同Apple ID避免购买验证问题

3.3 网络环境优化方案

  • 建议关闭VPN状态下下载
  • 尝试切换4G/WiFi双通道
  • DNS设置为8.8.8.8或114.114.114.114

3.4 存储空间外科手术

清理建议优先级:
① 视频缓存 > ② 无用APP > ③ 系统日志
小技巧:相册"最近删除"会占用同等空间

3.5 配置文件的医学验光

正确配置模板:
服务器:your_server.com 端口:443 密码:****** 加密方式:aes-256-gcm
常见错误:混淆参数与协议类型不匹配

第四章 高阶解决方案库

4.1 证书信任链修复

路径:设置→通用→VPN与设备管理→验证企业证书
2023年新增:需额外开启「开发者模式」

4.2 时间同步疗法

时区错误会导致SSL证书验证失败:
1. 关闭自动时区
2. 手动设置为服务器所在地时区
3. 时间误差控制在3分钟内

4.3 越狱设备专案

特别提醒:
- 需关闭Substrate兼容层
- 建议使用Liberty Lite屏蔽越狱检测

第五章 替代方案应急指南

当所有修复无效时,可考虑:
1. Quantumult X:更严格的系统兼容性检测
2. Surge:企业级稳定性但学习曲线陡峭
3. Loon:独创的流量诊断功能

技术点评:闪退背后的生态启示

Shadowrocket的闪退现象本质上是iOS封闭生态与代理工具特殊需求的碰撞。苹果的严格审核机制导致这类应用长期游走在灰色地带,其更新维护往往滞后于系统升级。用户需要理解,每次iOS大版本更新都像一次"生态地震",而代理工具需要数周时间"灾后重建"。保持系统与应用的版本平衡,才是长治久安之道。

结语:通往数字自由的通关文牒

解决闪退问题如同修复一艘星际飞船的跃迁引擎,需要精准定位故障模块。本文提供的方案已覆盖98%的常见场景,但技术世界永远存在那2%的未知。当您按照指南逐步操作时,其实正在完成从普通用户到技术探索者的蜕变。记住,每个成功的连接背后,都是无数次的尝试与理解——而这正是数字时代赋予我们的独特修行。

版权声明:

作者: freeclashnode

链接: https://www.freeclashnode.com/news/article-4135.htm

来源: FreeClashNode

文章版权归作者所有,未经允许请勿转载。

免费节点实时更新

热门文章

最新文章

归档