Go | 三索引切片

Go | 三索引切片

1. 简介

三索引切片主要是为了防止,在一个切片是建立在另一个切片之上时,扩充长度修改底层切片的内容。

正常语法slice[i:j],三索引语法slice[i:j:k]

  • i:开始索引
  • j:结束索引(不包含自身)
  • k:容量(条件:j-i <= k <= len(slice))

可以简单理解在k没有指定情况下默认k=len(slice)

图示

在这里插入图片描述

func main() {
	s1 := []int{1, 2, 3, 4, 5, 6, 7, 8}
	
	s2 := s1[2:5]
	fmt.Printf("s2 value: %v len: %d cap: %d\n", s2, len(s2), cap(s2))

	s3 := s1[2:5:5]
	fmt.Printf("s3 value: %v len: %d cap: %d\n", s3, len(s3), cap(s3))
}

输出

s2 value: [3 4 5] len: 3 cap: 6
s3 value: [3 4 5] len: 3 cap: 3

2. 容易出错地方

在不指定k情况下,上层切片会使用下层切片的长度,append时会直覆盖底层切片的值,可能会引发意外情况。

func main() {
	s1 := []int{1, 2, 3, 4, 5, 6, 7, 8}
	s2 := s1[2:5]

	s2 = append(s2, 0)
	fmt.Printf("s1 value: %v len: %d cap: %d\n", s1, len(s1), cap(s1))
	fmt.Printf("s2 value: %v len: %d cap: %d\n", s2, len(s2), cap(s2))
}

输出

s1 value: [1 2 3 4 5 0 7 8] len: 8 cap: 8
s2 value: [3 4 5 0] len: 4 cap: 6

3. 解决方法

使用k去限制切片,在发生扩容时会自动创建新的切片。

func main() {
	s1 := []int{1, 2, 3, 4, 5, 6, 7, 8}
	s3 := s1[2:5:5]

	s3 = append(s3, 0)
	fmt.Printf("s1 value: %v len: %d cap: %d\n", s1, len(s1), cap(s1))
	fmt.Printf("s3 value: %v len: %d cap: %d\n", s3, len(s3), cap(s3))
}

输出

s1 value: [1 2 3 4 5 6 7 8] len: 8 cap: 8
s3 value: [3 4 5 0] len: 4 cap: 6

4. 参考

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yimtcode

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值