内容简介:Go中的slice的声明方法(有时候顺便也定义了),主要分为下面几种(以int为例):后面可以也可以不跟上初始值,如另外,直接从数组或者slice中再建立slice也是一种常见的模式:
声明与定义
Go中的slice的声明方法(有时候顺便也定义了),主要分为下面几种(以int为例):
[]int
后面可以也可以不跟上初始值,如
[]int
[]int {}
[]int {1,2,3}
另外,直接从数组或者slice中再建立slice也是一种常见的模式:
c[l:h:c]
最后一种是通过make来创建:
make([]int, len, cap)
其中len,cap都是可选的,如果没有cap,缺省就是len那么大,如果没有len,缺省就是0。
添加
内置函数append是范型的添加,可以添加一个或者多个元素,也可以直接添加另外一个slice,这时候,需要使用 ...
运算符进行解包,如:
append(a, [] int {1,2,3}...)
不常用但是有时候也有用的,就是在slice的头部添加元素,象这样:
append([]int{1,2,3}, a)
头部添加开销一般比较大,需要移动元素甚至重新分配内存。
空slice与nil slice
空slice是len与cap都为0的slice,而nil slice则没有指向一个对象,这两者是有区别的。
以上所述就是小编给大家介绍的《golang的slice》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- golang的slice
- 剖析golang slice的实现
- 正确理解golang slice的复制
- golang中slice的注意事项
- golang slice append 后 capacity 增长的算法
- Golang的slice为何一定要len和cap二者
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
计算机程序设计艺术(第3卷)-排序和查找(英文影印版)
(美)Donald E.Knuth / 清华大学出版社 / 2002-9 / 85.00元
《计算机程序设计艺术排序和查找(第3卷)(第2版)》内容简介:这是对第3卷的头一次修订,不仅是对经典计算机排序和查找技术的最全面介绍,而且还对第1卷中的数据结构处理技术作了进一步的扩充,通盘考虑了将大小型数据库和内外存储器。它遴选了一些经过反复检验的计算机方法,并对其效率做了定量分析。第3卷的突出特点是对“最优排序”一节作了修订,对排列论原理与通用散列法作了全新讨论。一起来看看 《计算机程序设计艺术(第3卷)-排序和查找(英文影印版)》 这本书的介绍吧!