golang切片slice

切片slice是引用类型 len()函数获取元素的个数 cap()获取数组的容量

1.申明方式

(1)var a []int 与数组不同的是他不申明长度
(2)s2 := make([]int, 3, 10) //元素的类型,元素的数量,元素的容量
    fmt.Println(len(s2), cap(s2)) 输出元素的数量和容量

2.讲数组转换成切片

2 a := [10]int{}
3 fmt.Println(a)
4     s1 := a[:10]  //取前10个元素 [5:]取 5-最后的元素
5     fmt.Println(s1)

3.slice测试

1 a := []byte{‘a‘, ‘b‘, ‘c‘, ‘d‘, ‘e‘, ‘f‘, ‘h‘}
2 sa := a[2:5]
3 fmt.Println(string(sa))
4 sd1 := a[3:5]
5 fmt.Println(string(sd1)) //看看效果 

我们看到这样的是slice_a指向Array_ori 其实是从c指向到k 我们用fmt.Println(cap(slice_a)) 结果肯定不是3

自己动手试一下下边这个

     a := []byte{‘a‘, ‘b‘, ‘c‘, ‘d‘, ‘e‘, ‘f‘, ‘h‘}
    sa := a[2:5]
fmt.Println(string(sa))
    s := sa[1:3]
    fmt.Println(string(s))
    s2 := sa[3:5]
    fmt.Println(string(s2))

4.Apppend的用法
当使用append的时候,我们追加元素到切片的尾部,如果我们追加的在slice容量之中的时候我们会发现,

内存地址是不改变的,如果我们追加的超过容量了,内存地址也就改变了

1 a := make([]int, 3, 6)
2     fmt.Printf("%p", a)
3     a = append(a, 1, 2, 3)
4     fmt.Printf("%v %p\n", a, a)
5     a = append(a, 1, 2, 3)
6     fmt.Printf("%v %p\n", a, a)

运行如下图

slice是指向底层的数组,如果多个slice指向同一个的时候,其中一个改变了,其他的都改变。试一下下边这个

1 a := []int{1, 2, 3, 4, 5}
2 s1 := a[2:5]
3 s2 := a[1:3]
4 fmt.Println(s1, s2)
5 s1[0] = 9
6 fmt.Println(s1, s2)

当slice中append追加的元素超过了指向的容量,就会重新指向一个新的底层数组,

所以一个底层数组的改变,不会带动其他的改变,

试一下下边的代码

1
2 a := []int{1, 2, 3, 4, 5}
3 s1 := a[2:5]
4 s2 := a[1:3]
5 fmt.Println(s1, s2)
6 s2 = append(s2, 1, 2, 2, 3, 3, 4, 5)
7 s1[0] = 9
8 fmt.Println(s1, s2)

5.copy
这是一个拷贝的函数,下边的代码是从s2拷贝到s1 然后我们会看到结果是[7 8 9 4 5]

如果是copy(s2,s1) 我们看到的结果是[1 2 3]

s1 := []int{1, 2, 3, 4, 5}
s2 := []int{7, 8, 9}
copy(s1, s2)
fmt.Println(s1)

转载自微度网络 http://www.widuu.com/archives/08/771.html

时间: 2024-10-10 06:10:48

golang切片slice的相关文章

Golang 入门 : 切片(slice)

切片(slice)是 Golang 中一种比较特殊的数据结构,这种数据结构更便于使用和管理数据集合.切片是围绕动态数组的概念构建的,可以按需自动增长和缩小.切片的动态增长是通过内置函数 append() 来实现的,这个函数可以快速且高效地增长切片,也可以通过对切片再次切割,缩小一个切片的大小.因为切片的底层也是在连续的内存块中分配的,所以切片还能获得索引.迭代以及为垃圾回收优化的好处.本文将介绍 Golang 切片的基本概念和用法,演示环境为 ubuntu 18.04 & go1.10.1. 切

Go 灵活多变的切片Slice

我们知道数组定义好之后其长度就无法再修改,但是,在实际开发过程中,有时候我们并不知道需要多大的数组,我们期望数组的长度是可变的, 在 Go 中有一种数据结构切片(Slice) 解决了这个问题,它是可变长的,可以随时向Slice 里面添加数据. 1 什么是切片(Slice) 在 Go 源码中是这样定义切片的,源码地址:https://github.com/golang/go/blob/master/src/runtime/slice.go type slice struct { array uns

golang的slice作为函数参数传值的坑

直接贴代码 func sliceModify(slice []int) { // slice[0] = 88 slice = append(slice, 6) } func main() { slice := []int{1, 2, 3, 4, 5} sliceModify(slice) fmt.Println(slice) } 返回的没变,坑爹的,这个设计太那啥了,可以正确跑出效果的版本如下: func sliceModify(slice *[]int) { *slice = append(*

Go语言之切片Slice练习

切片Slice理论知识 其本身并不是数组,它指向底层的数组 作为编程数组的替代方案,可以关联底层数组的局部或者全部 为引用类型 可以直接创建或从底层数组获取生成 使用len()获取元素个数,cap()获取容量 一般使用make()创建 如果多个slice指向相同底层数组,其中一个的值改变会影响全部 make([]T, len, cap) 其中,cap可以省略,则和len的值相同 len表示存数的元素个数,cap表示容量 slice与底层数组的关系 Reslice Reslice时索引以被slic

golang切片类型

切片slice 其本身并不是数组,它指向底层的数组 作为变长数组的替代方案,可以关联底层数组的局部或全部 为引用类型 可以直接创建或从底层数组获取生成 使用len()获取元素个数,cap()获取容量 一般使用make()创建 如果多个slice指向相同底层数组,其中一个的值改变会影响全部 make([]T,len,cap) 其中cap可以省略,则和len的值相同 len表示存数的元素个数,cap表示容量 slice的定义方式 package main import ( "fmt" )

golang的slice了解及验证

golang 中slice的操作 golang收获 如果只是分配了 var st []SelfType, 进行赋值,那么就会是吧,除非使用 make 分配一个内存空间 注意, slice在make的时候可以制定 len, cap长度, len,cap的区别在于: len是当前slice中的element的长度, cap是slice的长度(在自动扩展之后) slice在使用的时候最好要区分出数据量的大小是否可以预期,如果是数据量很大,且不确认会有多少的时候,使用append的时候会浪费时间在内存c

(一)Python入门-2编程基本概念:16字符串-切片slice操作-逆序

一:字符串切片slice操作 切片 slice 操作可以让我们快速的提取子字符串.标准格式为: [起始偏移量start:终止偏移量end:步长 step] 典型操作(三个量为正数的情况)如下: 操作和说明 示例 结果 [:] 提取整个字符串 “abcdef”[:] “abcdef” [start:]从start 索引开始到结尾 “abcdef”[2:] “cdef” [:end]从头开始直到end-1 “abcdef”[:2] “ab” [start:end]从start 到 end-1  “a

数组array和切片(slice)的区别

一 数组简介: 数组是内置(build-in)类型,是一组同类型数据的集合,它是值类型,通过从0开始的下标索引访问元素值.在初始化后长度是固定的,无法修改其长度.当作为方法的参数传入时将复制一份数组而不是引用同一指针.数组的长度也是其类型的一部分,通过内置函数len(array)获取其长度.注意:和C中的数组相比,又是有一些不同的 1. Go中的数组是值类型,换句话说,如果你将一个数组赋值给另外一个数组,那么,实际上就是将整个数组拷贝一份2. 如果Go中的数组作为函数的参数,那么实际传递的参数是

Golang:slice之append时原数组发生变化的问题

使用append可以在slice之后追求元素,例如 nums:=[]int{1,2,3} result:=append(nums,4) fmt.Println(result) 这段代码很简单,输出result的值为:[1 2 3 4] 问题在于,进行这种操作时,原来的slice(即nums)所基于的数组的值会不会发生变化呢?在Golang中,如果有多个slice基于了同一个数组,则这些slice的数据是共享的(而不是每个slice复制一份).也就说,如果改变了数组的内容,则基于它的所有slice