go语言中切片的长度和容量的区别
切片的长度,显而易见的就是元素的个数,根据元素的个数进行返回具体的长度。
切片的长度,更像是一个警戒值,如果长度与容量相等,就会进行容量的扩容,比如
des :=make([]int , 3 , 5) //此时,长度为3,容量为5,但是如果使用append(), //切片长度会变为4,再次使用append()切片长度变为5。 //此时,切片长度与容量相同,此时,切片的容量增大变为cap = len*2
也就是通过一个容量设警戒值,如果等于警戒值,就会自动将切片进行扩容
补充:Go语言中切片的长度与容量的变化
在学习go语言的切片信息时,发现切片的容量变化非常让人摸不着头脑,为了更记忆深刻就写下了这篇,如有错误之处,请大家指正
一,当前切片的长度与容量相等情况:
package main import ( "fmt" ) func main() { numbers := []int{0,1,2} printSlice(numbers) //通过append给numbers增加信息,如果当前切片的长度与容量相等,增加信息的长度小于等于原来的长度, 那么切片的长度变为相加之和,容量变为原来的2倍(图片一的第二行结果) numbers = append(numbers, 10,5,6) printSlice(numbers) //通过append给numbers增加信息,如果当前切片A的长度与容量相等,增加信息B的长度大于切片A原来的长度, 那么切片的长度变为相加之和,容量变为:B长度+A长度+(B长度-A长度)%2(图片一的第三行结果) numbers = append(numbers, 12,13,15,16,17,18,19,20,21,22,23) printSlice(numbers) } func printSlice(x []int){ fmt.Printf("len=%d cap=%d slice=%v\n",len(x),cap(x),x) }
图片一:
二,如果当前切片的长度小于容量情况:
增加信息的长度与当前长度和小于等于容量
func main() { /* 创建切片 */ numbers := []int{0,1,2} printSlice(numbers) numbers = append(numbers, 10,5) printSlice(numbers) //通过append给numbers增加信息,如果当前切片的长度小于容量,增加信息的长度与当前长度和小于等于容量, 那么numbers的长度变为相加之和,容量不变(图片二的第三行结果) numbers = append(numbers, 11) printSlice(numbers) }
图片二:
增加信息B的长度与当前A的长度大于A容量并且小于A容量的2倍
func main() { /* 创建切片 */ numbers := []int{0,1,2} printSlice(numbers) numbers = append(numbers, 10,5) printSlice(numbers) //通过append给numbers增加信息,如果当前切片A的长度小于容量,增加信息B的长度与当前A的长度大于A容量并且小于A容量的2倍, 那么numbers的长度变为相加之和,容量变为:A容量*2(图片三的第三行结果) numbers = append(numbers, 11,12) printSlice(numbers) }
图片三:
增加信息B的长度与当前A的长度大于A容量的2倍
func main() { /* 创建切片 */ numbers := []int{0,1,2} printSlice(numbers) numbers = append(numbers, 10,5) printSlice(numbers) //通过append给numbers增加信息,如果当前切片A的长度小于容量,增加信息B的长度与当前A的长度大于A容量的2倍, 那么numbers的长度变为相加之和C。容量变为:B长度+A长度+(B长度-A长度)%2(图片四的第三行结果) numbers = append(numbers, 11,12,13,15,16,17,18,19,20) printSlice(numbers) }
图片四:
以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。如有错误或未考虑完全的地方,望不吝赐教。
赞 (0)