码迷,mamicode.com
首页 > 其他好文 > 详细

golang切片slice

时间:2015-03-12 18:48:11      阅读:91      评论:0      收藏:0      [点我收藏+]

标签:

切片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

 

golang切片slice

标签:

原文地址:http://www.cnblogs.com/chuanheng/p/golang_slice.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!