当前位置: 首页 > news >正文

物流网络规划名词解释烟台优化网站建设

物流网络规划名词解释,烟台优化网站建设,360手机助手,深圳住房和建设厅网站首页目录 切片的底层数据结构 扩容机制 总结: 练习验证代码 这是切片的底层探索下篇,上篇地址请见:GO语言-切片底层探索(上) 在上篇我们讲解了切片的两个重要实现或者说是两个特征 切片是引用类型,会进行…

目录

切片的底层数据结构

扩容机制

总结:

练习验证代码


这是切片的底层探索下篇,上篇地址请见:GO语言-切片底层探索(上)

在上篇我们讲解了切片的两个重要实现或者说是两个特征

  1. 切片是引用类型,会进行引用传递;
  2. 切片会随着元素数量的增加,进行扩容,改变其底层数组的指向;

这篇文章我们将会顺着讲解切片的底层数据结构和扩容机制

切片的底层数据结构

我们可以在src/runtime/slice.go下看到切片slice的底层数据结构:

type slice struct {array unsafe.Pointerlen   intcap   int
}

我们可以发现,切片slice的基础定义很简单:

  • 指针类型的array,指向底层数组
  • int类型的len,存储切片的长度
  • int类型的cap,存储切片的容量

由于在slice结构体中直接定义了len、cap字段,因此我们平常使用len(slice)和cap(slice),其时间复杂度为O(1),不需要遍历整个切片。

扩容机制

Go语言切片的扩容机制由基本机制和调整机制组成

func growslice(oldPtr unsafe.Pointer, newLen, oldCap, num int, et *_type) slice {.....newcap := oldCapdoublecap := newcap + newcapif newLen > doublecap {newcap = newLen} else {const threshold = 256if oldCap < threshold {newcap = doublecap} else {// Check 0 < newcap to detect overflow// and prevent an infinite loop.for 0 < newcap && newcap < newLen {// Transition from growing 2x for small slices// to growing 1.25x for large slices. This formula// gives a smooth-ish transition between the two.newcap += (newcap + 3*threshold) / 4}// Set newcap to the requested cap when// the newcap calculation overflowed.if newcap <= 0 {newcap = newLen}}}......
}

基本机制:

  1. 如果新切片的长度大于旧切片的二倍容量,就直接令新切片的容量等于新切片的长度
  2. 如果旧切片的容量小于256,进行二倍扩容
  3. 如果就切片的容量大于等于256,按照newcap+=(newcap+3*threshold)/4公式进行扩容,扩容速度减缓,向1.25倍进行过渡。

在基本扩容规则的基础上,还会考虑元素类型与内存分配规则,对实际的扩张值做一些微调。从这一个基本规则中我们可以看出Go语言对slice性能和空间使用率的思考:

  • 当切片较小时,采用较大的扩容倍速,可以避免频繁地扩容,从而减少内容分配次数和数据拷贝的代价。
  • 当切片较大时,采用较小的扩容倍速,主要是为了避免空间浪费。

 因此,使用append()向slice添加一个元素的实现步骤如下:

  1. 假如slice容量够用,则将新元素追加进去,slice.len++,返回原slice
  2. 原slice容量不够,则将slice先扩容,扩容后得到新slice
  3. 将新元素追加进新slice,slice.len++,返回新的slice。

总结:

切片是go语言中常用的容器,由于其扩容特性,容易发生一些不容易被发现的错误,这就需要我们对切片的底层扩容机制有足够的了解,知道什么时候切片会进行扩容操作和如果高效地使用切片进行数据的存储和处理。

练习验证代码

package mainimport "fmt"type student struct {name    stringage     intaddress string
}func main() {//256以下的二倍扩容slice := make([]int, 255)fmt.Println(len(slice), cap(slice))newSlice := append(slice, 2)fmt.Println(len(newSlice), cap(newSlice))
}/*func main() {//结构体指针类型切片cap为1024的1.5倍扩容array := make([]*student, 1024)fmt.Println(len(array), cap(array))slice := arrayslice = append(slice, &student{name: "wang", age: 12, address: "河南"})fmt.Println(len(slice), cap(slice))
}*//*func main() {//结构体类型切片cap为1024的1.6倍扩容array := make([]student, 1024)fmt.Println(len(array), cap(array))slice := arrayslice = append(slice, student{name: "wang", age: 12, address: "河南"})fmt.Println(len(slice), cap(slice))
}*///func main() {
//	//int类型的cap为1024的1.5倍扩容
//	array := make([]int, 1024)
//	fmt.Println(len(array), cap(array))
//	slice := array
//	slice = append(slice, 1)
//	fmt.Println(len(slice), cap(slice))
//}
http://www.yayakq.cn/news/100766/

相关文章:

  • 中国住房和建设部网站中国电信网站备案
  • dedecms手机网站制作当阳建设中学网站
  • 门户网站建设的成果做那个男女的视频网站
  • 手机下载视频网站模板下载失败电商网站运营团队建设方案模板
  • 个人网站需要建站群吗消防工程师证怎么考
  • 洛阳网站建设价格建筑网课平台哪个好
  • 专业的营销型网站建设广州网站开发工程师
  • 郑州 外包网站计算机培训机构
  • 网站公司做的网站有最字dede网站wap
  • 平板电脑做网站吗二级学院网站制度建设
  • 专业做旅游网站的公司游戏推广员是做什么的
  • 广州网站建设推广公司惠城网站建设服务
  • 网站前端浏览器兼容如何做陈巴尔虎旗网站建设
  • 国外做电商网站有哪些官网建立
  • 织梦网站地图如何做php学校网站源码
  • dede移动端网站源码网站设计要点 优帮云
  • wordpress只能显示字上海市网站seo
  • 精品网站建设费用 尖端磐石网络h5制作官网登录
  • 网站建设上的新闻建设企业银行登录
  • 网站编辑兼职网站建设岗位
  • 装修设计网站排名在线课程设计
  • 网站收录500多页官网设计公司
  • 如何规避电子政务门户网站建设photoshop网站视觉设计步骤
  • 河南建设工程信息网下载秦皇岛哪有网站优化公司
  • 怎么做网站推广和宣传一般网站建设公司有哪些
  • 地方门户网站的推广普通话手抄报简单又漂亮
  • 圣亚科技网站案例wordpress mysql8.0
  • 中兴建设云南有限公司网站公司注册网站需要提供什么文件
  • 论坛网站模wordpress异步上传图片
  • 搭建视频播放网站小程序发布流程在哪里