切片Slice在go语言中是单独的类型(指向底层的数组),不同于python(对可迭代对象操作的工具),注意区分数组和slice的区别

  • 定义一个空slice,格式var s []int,这种既没有长度也没有元素赋值的类型(相比叫array)

  • 数组的基本操作如下 ,类似与python中列表切片的操作,详见实例

    package main
    import "fmt" func main() {
    var s1 []int //这样就是一个slice类型,既没有长度也没有元素赋值
    a := [10]int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10} //这是一个数组
    s2 := a[5:10] //切片,索引5到10的元素,不包含索引为10
    s3 := a[:3] //切片,索引1-3的元素,不包含索引3
    s4 := a[6:] //切片,第6个索引到最后一个索引的元素
    s5 := a[:] //切片,复制一个数组
    fmt.Println(s1)
    fmt.Println(a)
    fmt.Println(s2) //数组的切片,类似python
    fmt.Println(s3)
    fmt.Println(s4)
    fmt.Println(s5)
    } /*输出
    s1---> []
    a---> [0 0 0 0 0 0 0 0 0 0]
    s2---> [6 7 8 9 10]
    s3---> [1 2 3]
    s4---> [7 8 9 10]
    s5---> [1 2 3 4 5 6 7 8 9 10]
    */

使用make初始化一个slice类型,包含三个参数

  • ①切片类型 []int

  • ②初始长度 len

  • ③容量 cap

    package main
    import "fmt" func main() {
    s1 := make([]int, 3, 10) //使用make初始化一个slice,包含三个参数:①切片类型②初始长度③容量
    fmt.Println(len(s1), cap(s1)) //输出长度,容量
    fmt.Println(s1)
    } /*输出:
    len(s1)--->3
    cap(s1)--->10
    s1---> [0 0 0] //可变数组
    */

Reslice ,在原slice基础上再次切片,slice一个数组时,不仅取出了len,同时容量也会得到相应的切片。

  • 示例

    //Reslice,在slice基础上再次slice.
    package main
    import "fmt" func main() {
    a := []byte{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'k', 'm'} //定义一个数组,元素为byte类型
    sa := a[3:5] // slice切片,取索引三到五,不包含索引5
    sb := sa[1:3]
    fmt.Println(string(sa))
    fmt.Println(len(sa), cap(sa))
    fmt.Println(string(sb))
    fmt.Println(len(sb), cap(sb))
    } /*输出
    sting(sa)---> de
    len(sa)---> 2
    cap(sa)---> 6
    string(sb)---> ef
    len(sb)---> 2
    cap(sb)---> 5
    */

Append,类似python中list类型,使用append,从数组尾部追加元素

  • 可以将一个slice追加在另一个slice尾部

  • 如果最终长度未超过追加到slice的容量,则返回原始slice

  • 如果超过追加的slice的容量则将重新分配数组并拷贝原始数据

    package main
    import "fmt" func main() {
    s1 := make([]int, 3, 8) //初始化slice,长度位3,容量为8
    fmt.Printf("%p\n", s1) //输出s1的内存地址
    fmt.Println(s1)
    s1 = append(s1, 1, 2, 3) //末尾追加三个元素,cap依然为8
    fmt.Printf("%p\n", s1) //原来的slice
    fmt.Println(s1)
    s1 = append(s1, 1, 2, 3, 4) //继续追加元素,超过原s1容量,会重新分配新的内存地址
    fmt.Printf("%p\n", s1) //cap容量超过8,为9
    fmt.Println(s1)
    } /*
    p*s1---> 0xc042070040
    s1---> [0 0 0]
    p*s1s1--> 0xc042070040
    s1---> [0 0 0 1 2 3]
    p*s1---> 0xc04205e080 //新的内存地址
    s1---> [0 0 0 1 2 3 1 2 3 4]
    */
  • 当两个slice同时指向某一个数组时,改变某一个slice索引时,另一个slice索引值及原数组的索引也会改变

    package main
    import "fmt" func main() {
    a := []int{1, 2, 3, 4, 5, 6}
    s1 := a[2:5]
    s2 := a[1:3]
    fmt.Println(s1, s2)
    s1[0] = 9
    fmt.Println(s1, s2)
    fmt.Println(a)
    } /*
    s1---> [3 4 5]
    s2---> [2 3]
    //更改s1的slice索引后,s2的索引也会改
    s1---> [9 4 5]
    s2---> [2 9]
    a---> [1 2 9 4 5 6]
    */

copy,格式 copy(s1,s2), 将s2拷贝到s1数组中,当len(s1) > len(s2)时,最终将s2中的索引

替换掉s1的索引,当len(s1)<len(s2)时,s1的索引值全部被对应s2的索引替换

  • 示例

    package main
    import "fmt" func main() {
    s1 := []int{1, 2, 3, 4, 5}
    s2 := []int{6, 7, 8}
    copy(s1, s2) //将s2的元素拷贝到s1,s2
    fmt.Println(s1) copy(s2, s1)
    fmt.Println(s2) copy(s1, s2[2:3]) //只拷贝某一切片的索引
    fmt.Println(s1)
    } /*输出
    s1---> [6 7 8 4 5]
    s2---> [1 2 3]
    s1---> [8 2 3 4 5]
    */

golang基础---Slice切片的更多相关文章

  1. GoLang基础数据类型-切片(slice)详解

    GoLang基础数据类型-切片(slice)详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 数组的长度在定义之后无法再次修改:数组是值类型,每次传递都将产生一份副本.显然这种数 ...

  2. golang:slice切片

    一直对slice切片这个概念理解的不是太透彻,之前学习python的就没搞清楚,不过平时就用python写个工具啥的,也没把这个当回事去花时间解决. 最近使用go开发又遇到这个问题,于是打算彻底把这个 ...

  3. 【玩转Golang】slice切片的操作——切片的追加、删除、插入等

    一.一般操作 1,声明变量,go自动初始化为nil,长度:0,地址:0,nil func main(){ var ss []string; fmt.Printf("length:%v \ta ...

  4. golang slice切片的原理以及内置函数cap, len

    golang中slice(切片)是常用的类型, slice是对数组进行封装 package main import ( "fmt" "strconv") fun ...

  5. golang slice 切片原理

    golang 中的 slice 非常强大,让数组操作非常方便高效.在开发中不定长度表示的数组全部都是 slice .但是很多同学对 slice 的模糊认识,造成认为golang中的数组是引用类型,结果 ...

  6. Golang基础之函数

    golang基础之函数 1.为什么需要函数? 有些相同的代码可能出现多次,如果不进行封装,那么多次写入到程序中,会造成程序冗余,并且可读性降低 2.什么是函数 为完成某些特定功能的程序指令集合称为函数 ...

  7. Golang 基础之基础语法梳理 (一)

    大家好,今天将梳理出的 Go语言基础语法内容,分享给大家. 请多多指教,谢谢. 本次<Go语言基础语法内容>共分为三个章节,本文为第一章节 Golang 基础之基础语法梳理 (一) Gol ...

  8. Golang基础教程

    以下使用goland的IDE演示,包含总计的golang基础功能共20个章节 一.go语言结构: 二.go基础语法: 三.变量 四.常量 五.运算符 六.条件语句 七.循环 八.函数 九.变量作用域 ...

  9. Go语言基础之切片

    Go语言基础之切片 本文主要介绍Go语言中切片(slice)及它的基本使用. 引子 因为数组的长度是固定的并且数组长度属于类型的一部分,所以数组有很多的局限性. 例如: func arraySum(x ...

随机推荐

  1. C语言编程学习:写的秒速计算四则混合运算项目

    C语言是面向过程的,而C++是面向对象的 C和C++的区别: C是一个结构化语言,它的重点在于算法和数据结构.C程序的设计首要考虑的是如何通过一个过程,对输入(或环境条件)进行运算处理得到输出(或实现 ...

  2. 526. Beautiful Arrangement

    Suppose you have N integers from 1 to N. We define a beautiful arrangement as an array that is const ...

  3. mySQL授权(让从服务器用户可以登录到主服务器)

    mySQL授权(让从服务器用户可以登录到主服务器) 1.查看用户授权表 ? 1 select user,host,password from mysql.user; 2.给用户设置密码 ? 1 2 u ...

  4. Access MongoDB Data with Entity Framework 6

    This article shows how to access MongoDB data using an Entity Framework code-first approach. Entity ...

  5. linux新服务器分区挂载

    新买一台服务器,需要自己手动对硬盘进行分区挂载:(这是centos下,其他版本应该也类似) 1.查看没有分区的硬盘:fdisk  -l  由图上信息可知,该服务器由三块硬盘 vda.vdb.vdc,其 ...

  6. Kettle 值映射

    在费用转换里面做了两个值映射.一个是编码.一个是名称.其中两个值映射设置不一样效果不一样. 第一个编码映射 目标字段名不为空,则表示会新增字段.其中复核源值条件的都会转换为目标值,不符合条件的会用[不 ...

  7. FPGA基础学习(9) -- 复位设计

    目录 1. 常见问题 2. 常见的复位方式 3. 合理的复位设计 3.1 复位电平 3.2 异步复位同步化 3.3 恰到好处的复位 4. 补充 4.1 所谓的上电初始化 参考文献 一开始接触到FPGA ...

  8. linux的sed(增删改查)使用方法

    sed的增删改查的基本操作 参考:https://www.cnblogs.com/0zcl/p/6855740.html 01:增(a) 2个sed命令,分别是:(这些操作都是在内存中进行的,所以不会 ...

  9. HihoCoder - 1513 bitset处理五维偏序

    题意:给出\(n<3e4\)个有序组\((a,b,c,d,e)\),求对第\(i\)个有序组有多少个\(j\)满足\((a_j<a_i,b_j<b_i,c_j<c_i,d_j& ...

  10. golang (2) package

    综述 golang package是基本的管理单元,package是golang最基本的分发单位和工程管理中依赖关系的体现. 每个golang源代码文件开头都拥有一个package声明,表示该gola ...