数组传参改不了原值,切片能改但可能意外影响别人;大数组应传指针或转切片;截取切片需防重叠;用copy隔离数据;len是当前长度,cap是容量上限;预估最大量设cap可避免频繁扩容;数组可比较、作map键,切片不可。数组传参改不了原值,切片能改但可能意外影响别人Go里arr 3int传进函数后,函数里改的是副本,外面完全没变;而s \[\]int传进去,改的是底层数组,原切片能看到变化------但危险在于:如果多个切片共享同一底层数组,一个append或赋值可能悄悄改掉另一个的元素。大数组别直接传参,要么传*1024byte指针,要么转成切片再传截取切片时注意重叠:a := arr1:3和b := arr2:4共用arr2,改a1等于改b0需要隔离数据?用copy(dst, src)新建独立切片,别依赖make(\[\]T, len(src))后直接赋值len和cap不是一回事,扩容时机全看cap够不够len(s)是你现在能读写的元素个数,cap(s)是"还能往里塞多少而不换底层数组"。很多bug就出在以为len == cap,结果append后返回的新切片指向了新地址,老变量还指着旧内存。s := make(\[\]int, 0, 5):长度0、容量5,第一次append(s, 1)不扩容,底层数组还是那块s := \[\]int{1,2,3}:长度3、容量也是3,再append必然扩容,底层数组大概率换地方频繁追加?预估最大量设好cap,比如日志缓冲make(\[\]byte, 0, 4096),省掉多次复制初始化写法决定底层是否复用,零值行为也完全不同数组零值是3int{0,0,0},切片零值是nil。这直接影响if s == nil判断和append行为------对nil切片append是安全的,但对nil数组?压根不能nil数组,它必须有长度。var s \[\]int → s是nil,len(s)==0且cap(s)==0,可直接appendvar a 3int → a是3int{0,0,0},不能append,也不能nil比较s := \[\]int(nil)和s := \[\]int{}都合法,但前者cap==0,后者cap通常为小整数(如2),影响首次扩容策略什么时候非用数组不可?固定大小+可比较+当map键切片不能做map的键,也不能用==直接比较;数组可以。典型场景:SHA256哈希值32byte、RGB颜色3uint8、矩阵行4float64。 Vozo Vozo是一款强大的AI视频编辑工具,可以帮助用户轻松重写、配音和编辑视频。
相关推荐
love530love19 小时前
LiveTalking 数字人项目 Windows 部署完全指南(EPGF 架构)遇事不決洛必達19 小时前
【Python基础】GIL 锁是什么及其对爬虫的影响Micro麦可乐19 小时前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)海兰19 小时前
【水浒传:第二篇】AI江湖 —项目详细设计指南(一)码农阿豪19 小时前
从零到一:Spring Boot快速接入金仓数据库实战鼎讯信通20 小时前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题CryptoPP20 小时前
快速对接东京证券交易所API数据:实战指南与代码示例三十..20 小时前
MySQL 从入门到高可用架构实战精要探物 AI21 小时前
把 MambaOut 塞进 YOLOv11:会有什么样的反应cfm_291421 小时前
Redis五大基本数据结构底层了解