你会吗? 为什么长度为零的切片sl, 可以是用 sl[0:5] 而不报错
报错 为什么 可以 长度 切片 sl
2023-06-13 09:16:10 时间
- 在 golang 中, 所有传递都是值传递。
- 切片是引用类型, 所以在函数中可以修改底层数据。 结合第一条, 函数内的切片 和 函数外的切片不是同一个。
- sl[0:5] 操作的是 **底层** 数据, 并返回了新一个切片。
package main
import "fmt"
func main() {
sl := make([]int, 0, 10)
appendFn := func(s []int) {
// 值传递, s 并不是 sl。
// 但数组是引用类型, 所以可以修改底层数组
fmt.Println("s ptr(old):", s) // []
s = append(s, 10, 20, 30)
fmt.Println("s ptr(new):", s) // [10,20,30]
}
fmt.Println(sl) // []
appendFn(sl)
fmt.Println(sl) // []
// 这里要注意, 并不是取的 sl ,而是底层数组新创建的 slice
fmt.Println(sl[:5]) // [10,20,30,0,0]
// 等价于
sl1 := sl[:5]
fmt.Println(sl1) // [10,20,30,0,0]
}
相关文章
- newarr[x].push(arr[i]) 为什么这样写会报错?
- ORA-47004: error updating Factor Type string, string ORACLE 报错 故障修复 远程处理
- ORA-00912: input parameter too long ORACLE 报错 故障修复 远程处理
- MySQL Error number: MY-010496; Symbol: ER_NDB_BINLOG_FAILED_CREATE_EVENT_OPERATIONS_DURING_RENAME; SQLSTATE: HY000 报错 故障修复 远程处理
- ORA-01451: column to be modified to NULL cannot be modified to NULL ORACLE 报错 故障修复 远程处理
- MySQL Error number: MY-011335; Symbol: ER_XPLUGIN_FAILED_TO_GET_SECURITY_CTX; SQLSTATE: HY000 报错 故障修复 远程处理
- ORA-06920: CMX: getbrkmsg illegal datatype ORACLE 报错 故障修复 远程处理
- MySQL Error number: MY-011758; Symbol: ER_LDAP_AUTH_GRP_SEARCH_SPECIAL_HDL; SQLSTATE: HY000 报错 故障修复 远程处理
- ORA-13469: cannot perform updateRaster operation ORACLE 报错 故障修复 远程处理
- MySQL Error number: MY-012498; Symbol: ER_IB_MSG_673; SQLSTATE: HY000 报错 故障修复 远程处理
- MySQL Error number: MY-012916; Symbol: ER_IB_MSG_1091; SQLSTATE: HY000 报错 故障修复 远程处理
- PostgreSQL HV008: fdw_invalid_column_number 报错 故障修复 远程处理
- 报错解决Oracle反斜杠报错问题(oracle反斜杠)