当前位置: 首页 > 编程笔记 >

深入解析Go语言编程中slice切片结构

闾丘选
2023-03-14
本文向大家介绍深入解析Go语言编程中slice切片结构,包括了深入解析Go语言编程中slice切片结构的使用技巧和注意事项,需要的朋友参考一下

数组转换成切片

 

a := [10]int{}

fmt.Println(a)

 s1 := a[:10]  //取前10个元素 [5:]取 5-最后的元素 

 fmt.Println(s1)


slice测试
 

a := []byte{'a', 'b', 'c', 'd', 'e', 'f', 'h'}

sa := a[2:5]

fmt.Println(string(sa))

sd1 := a[3: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))


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

a := []int{1, 2, 3, 4, 5}

s1 := a[2:5]

s2 := a[1:3]

fmt.Println(s1, s2)

s1[0] = 9

fmt.Println(s1, s2)

切片是引用类型,即如果赋值切片给另一个切片,它们都指向同一底层数组。例如,如果某函数取切片参量,对其元素的改动会显现在调用者中,类似于传递一个底层数组的指针。因此 Read 函数可以接受切片参量,而不需指针和计数;切片的长度决定了可读数据的上限。这里是 os 包的 File 型的 Read 方法的签名:

 

  func (file *File) Read(buf []byte) (n int, err os.Error)


此方法返回读入字节数和可能的错误值。要读入一个大的缓冲 b 的首32字节, 切片(动词)缓冲。
 

      n, err := f.Read(buf[0:32])


这种切片常用且高效。实际上,先不管效率,此片段也可读缓冲的首32字节。
 

      var n int

      var err os.Error

      for i := 0; i < 32; i++ {

          nbytes, e := f.Read(buf[i:i+1])  // Read one byte.

          if nbytes == 0 || e != nil {

              err = e

              break

          }

          n += nbytes

      }


只要还在底层数组的限制内,切片的长度可以改变,只需赋值自己。切片的容量,可用内部函数 cap 取得,给出此切片可用的最大长度。下面的函数给切片添值。如果数据超过容量,切片重新分配,返回结果切片。此函数利用了 len 和 cap 对 nil 切片合法、返回0的事实。


Apppend的用法
 

 

a := make([]int, 3, 6)

 fmt.Printf("%p", a)

 a = append(a, 1, 2, 3)

 fmt.Printf("%v %p\n", a, a)

 a = append(a, 1, 2, 3)

 fmt.Printf("%v %p\n", a, a)


我们必须返回切片,因为尽管 Append 可以改变 slice 的元素, 切片自身(持有指针、长度和容量的运行态数据结构)是值传递的。添加切片的主意很有用,因此由内置函数 append 实现。
 

  func Append(slice, data[]byte) []byte {

      l := len(slice)

      if l + len(data) > cap(slice) {  // reallocate

          // Allocate double what's needed, for future growth.

          newSlice := make([]byte, (l+len(data))*2)

          // Copy data (could use bytes.Copy()).

          for i, c := range slice {

              newSlice[i] = c

          }

          slice = newSlice

      }

      slice = slice[0:l+len(data)]

      for i, c := range data {

          slice[l+i] = c

      }

      return slice

  }

当slice中append追加的元素超过了指向的容量,就会重新指向一个新的底层数组,所以一个底层数组的改变,不会带动其他的改变,试一下下边的代码

 

a := []int{1, 2, 3, 4, 5}

s1 := a[2:5]

s2 := a[1:3]

fmt.Println(s1, s2)

s2 = append(s2, 1, 2, 2, 3, 3, 4, 5)

s1[0] = 9

fmt.Println(s1, s2)


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)

 类似资料:
  • Go 语言切片是对数组的抽象。 Go 数组的长度不可改变,在特定场景中这样的集合就不太适用,Go中提供了一种灵活,功能强悍的内置类型切片("动态数组"),与数组相比切片的长度是不固定的,可以追加元素,在追加时可能使切片的容量增大。 定义切片 你可以声明一个未指定大小的数组来定义切片: var identifier []type 切片不需要说明长度。 或使用make()函数来创建切片: var s

  • 本文向大家介绍深入解析Go语言编程中的递归使用,包括了深入解析Go语言编程中的递归使用的使用技巧和注意事项,需要的朋友参考一下 递归是以相似的方式重复项目的过程。同样适用于编程语言中,如果一个程序可以让你调用同一个函数被调用的函数,递归调用函数内使用如下。 Go编程语言支持递归,即要调用的函数本身。但是在使用递归时,程序员需要谨慎确定函数的退出条件,否则会造成无限循环。 递归函数是解决许多数学问题

  • 本文向大家介绍解析Go语言编程中的struct结构,包括了解析Go语言编程中的struct结构的使用技巧和注意事项,需要的朋友参考一下 struct和C语言的很相似,模拟出class的功能,但是不完全的!没有构造函数等! struct的申明 go指针操作 如下我们要对数值进行改变,先要取内存地址,然后再内存地址上改变他的引用 匿名结构 (1)匿名内部结构的使用 (2)匿名类值不需要数据名称、在赋值

  • 主要内容:从数组或切片生成新的切片,直接声明新的切片,使用 make() 函数构造切片切片(slice)是对数组的一个连续片段的引用,所以切片是一个引用类型(因此更类似于 C/ C++ 中的数组类型,或者 Python 中的 list 类型),这个片段可以是整个数组,也可以是由起始和终止索引标识的一些项的子集,需要注意的是,终止索引标识的项不包括在切片内。 Go语言中切片的内部结构包含地址、大小和容量,切片一般用于快速地操作一块数据集合,如果将数据集合比作切糕的话,切片就是你要的“

  • 本文向大家介绍Go语言中的Slice学习总结,包括了Go语言中的Slice学习总结的使用技巧和注意事项,需要的朋友参考一下 概念 Slice切片是对底层数组Array的封装,在内存中的存储本质就是数组,体现为连续的内存块,Go语言中的数组定义之后,长度就已经固定了,在使用过程中并不能改变其长度,而Slice就可以看做一个长度可变的数组进行使用,最为关键的,是数组在使用的过程中都是值传递,将一个数组

  • 本位主要介绍一下 Go 语言中可变长度的"数组"——切片(slice)。数组有数组的用处,但是其不可变长度的特性,注定了在大多场景下不是很受欢迎。在大多数场景下我们都会选择更加灵活的切片。 1. 切片的创建 切片的声明方式和数组类似,写法上看就是声明一个没有长度的数组:var 切片名 []切片类型。其中切片类型可以是切片本身,也就是切片的切片,就构成了多维的切片。 切片在使用之前必须要初始化,它没