数组传参改不了原值,切片能改但可能意外影响别人;大数组应传指针或转切片;截取切片需防重叠;用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视频编辑工具,可以帮助用户轻松重写、配音和编辑视频。
相关推荐
Cthy_hy6 小时前
Python算法竞赛:排列组合核心用法l1t6 小时前
DeepSeek总结的使用 PEG 实现运行时可扩展的 SQL 解析器这个DBA有点耶6 小时前
COUNT进阶(续):超大表去重计数的极致优化爱喝水的鱼丶6 小时前
SAP-ABAP:SAP 简单报表输出开发系列(共6篇) 第四篇:SAP 报表异常处理机制:数据校验与消息提示规范落地_1_76 小时前
SQL SERVER闪退问题解决C+-C资深大佬6 小时前
在PyCharm中创建虚拟环境的具体步骤是什么?ZengLiangYi6 小时前
sql.js WASM 深度解析一 乐7 小时前
人口老龄化社区服务与管理平台|基于springboot+vue的人口老龄化社区服务与管理平台(源码+数据库+文档)梓䈑7 小时前
【MySQL】表的操作(数据表的创建、查看 和 修改)Dxy12393102167 小时前
Python Tensor 向量入门:从零理解深度学习的“数据语言“