切片的长度,显而易见的就是元素的个数,根据元素的个数进行返回具体的长度。
切片的长度,更像是一个警戒值,如果长度与容量相等,就会进行容量的扩容,比如
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)
}
图片四:
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。
您可能感兴趣的文章:- go语言求任意类型切片的长度操作
- 如何在Go中使用切片容量和长度
- Go语言切片前或中间插入项与内置copy()函数详解
- golang中切片copy复制和等号复制的区别介绍
- go语言中切片与内存复制 memcpy 的实现操作
- go语言中的二维切片赋值