go语言切片源码讲解 go切片操作( 三 )


func test12() {
slice := []int32{1, 2, 3, 4, 5, 6}
slice2 := slice[:2]
_ = append(slice2, 50, 60, 70, 80, 90)
fmt.Printf("slice为:%v\n", slice)
fmt.Printf("操作的切片:%v\n", slice2)
_ = append(slice2, 50, 60)
fmt.Printf("slice为:%v\n", slice)
fmt.Printf("操作的切片:%v\n", slice2)
}
如上 , append方法用了2次,结果返回的结果完全不同,原因是第二次append方法追加的元素数量没有超过 slice 的容量 。而无论怎样,原切片slice2都无影响 。结果:
slice为:[1 2 3 4 5 6]
操作的切片:[1 2]
slice为:[1 2 50 60 5 6]
操作的切片:[1 2]
Golang 中数组(Array)和切片(Slice)的区别 Go 中数组的长度是不可改变的go语言切片源码讲解 , 而 Slice 解决的就是对不定长数组的需求 。他们的区别主要有两点 。
数组go语言切片源码讲解:
切片:
注意 1
虽然数组在初始化时也可以不指定长度,但 Go 语言会根据数组中元素个数自动设置数组长度 , 并且不可改变 。切片通过 append 方法增加元素:
如果将 append 用在数组上 , 你将会收到报错:first argument to append must be slice 。
注意 2
切片不只有长度(len)的概念 , 同时还有容量(cap)的概念 。因此切片其实还有一个指定长度和容量的初始化方式:
这就初始化了一个长度为3,容量为5的切片 。
此外,切片还可以从一个数组中初始化(可应用于如何将数组转换成切片):
上述例子通过数组 a 初始化了一个切片 s 。
当切片和数组作为参数在函数(func)中传递时,数组传递的是值,而切片传递的是指针 。因此当传入的切片在函数中被改变时,函数外的切片也会同时改变 。相同的情况,函数外的数组则不会发生任何变化 。
Go语言 排序与搜索切片Go语言标准库中提供go语言切片源码讲解了sort包对整型,浮点型 , 字符串型切片进行排序,检查一个切片是否排好序,使用二分法搜索函数在一个有序切片中搜索一个元素等功能 。
关于sort包内go语言切片源码讲解的函数说明与使用,请查看
在这里简单讲几个sort包中常用的函数
在Go语言中,对字符串的排序都是按照字节排序,也就是说在对字符串排序时是区分大小写的 。
二分搜索算法
Go语言中提供了一个使用二分搜索算法的sort.Search(size,fn)方法go语言切片源码讲解:每次只需要比较㏒?n个元素,其中n为切片中元素的总数 。
sort.Search(size,fn)函数接受两个参数:所处理的切片的长度和一个将目标元素与有序切片的元素相比较的函数,该函数是一个闭包 , 如果该有序切片是升序排列,那么在判断时使用 有序切片的元素 = 目标元素 。该函数返回一个int值 , 表示与目标元素相同的切片元素的索引 。
在切片中查找出某个与目标字符串相同的元素索引
Golang bytes.buffer详解Buffer 介绍
Buffer 是 bytes 包中的一个 type Buffer struct{…}
A buffer is a variable-sized buffer of bytes with Read and Write methods. The zero value for Buffer is an empty buffer ready to use.
(是一个变长的 buffer,具有 Read 和Write 方法 。Buffer 的 零值 是一个 空的 buffer,但是可以使用)
Buffer 就像一个集装箱容器 , 可以存东西,取东西(存取数据)
创建缓冲器
输出
写入到缓冲器
buffer在new的时候是空的,也是可以直接Write的
Write
结果
WriteString
结果
WriteByte
WriteRune
结果
从缓冲器中写出

推荐阅读