golang的slice

栏目: Go · 发布时间: 6年前

内容简介: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》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数据结构与算法

数据结构与算法

卓滋德克 / 陈曙晖 / 清华大学出版社 / 2003-4-1 / 69.00

本书是一本介绍数据结构与算法的优秀书籍。 本书系统介绍了C++面向对象程序设计、算法复杂度、链表、栈、队列、递归、树、图、排序和查找算法、散列技术、数据压缩算法、内存管理等内容;尤其对递归算法进行了深入剖析。在附录中详细介绍了大O符号与标准模板库:在大多数章中提供了相应的实例分析和程序设计作业。 本书适合作为计算机软件专业或其他相关专业的教科书。对于需要参加计算机考试,......一起来看看 《数据结构与算法》 这本书的介绍吧!

html转js在线工具
html转js在线工具

html转js在线工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具