mirror of
https://github.com/unknwon/the-way-to-go_ZH_CN.git
synced 2025-08-12 04:48:29 +08:00
68 lines
2.8 KiB
Markdown
68 lines
2.8 KiB
Markdown
# 7.5 切片的复制与追加
|
||
|
||
如果想增加 slice 的容量,我们必须创建一个新的更大的 slice 并把原分片的内容都拷贝过来。下面的代码描述了从拷贝 slice 的 copy 方法和向 slice 追加新元素的 append 方法。
|
||
|
||
示例 7.12 [copy_append_slice.go](examples/chapter_7/copy_append_slice.go)
|
||
|
||
package main
|
||
import "fmt"
|
||
|
||
func main() {
|
||
sl_from := []int{1, 2, 3}
|
||
sl_to := make([]int, 10)
|
||
|
||
n := copy(sl_to, sl_from)
|
||
fmt.Println(sl_to)
|
||
fmt.Printf("Copied %d elements\n", n) // n == 3
|
||
|
||
sl3 := []int{1, 2, 3}
|
||
sl3 = append(sl3, 4, 5, 6)
|
||
fmt.Println(sl3)
|
||
}
|
||
|
||
`func append(s[]T, x ...T) []T` 其中 append 方法将 0 个或多个具有相同类型 s 的元素追加到 slice 后面并且返回新的 slice;追加的元素必须和原 slice 的元素同类型。如果 s 的容量不足以存储新增元素,append 会分配新的 slice 来保证已有 slice 元素和新增元素的存储。因此,返回的 slice 可能已经指向一个不同的相关数组了。append 方法总是返回成功,除非系统内存耗尽了。
|
||
|
||
如果你想将 slice y 追加到 slice x 后面,只要将第二个参数扩展成一个列表即可:`x = append(x, y...)`
|
||
|
||
**注意**: append 在大多数情况下很好用,但是如果你想完全掌控整个追加过程,你可以实现一个这样的 AppendByte 方法:
|
||
|
||
```go
|
||
func AppendByte(slice []byte, data ...byte) []byte {
|
||
m := len(slice)
|
||
n := m + len(data)
|
||
if n > cap(slice) { // if necessary, reallocate
|
||
// allocate double what's needed, for future growth.
|
||
newSlice := make([]byte, (n+1)*2)
|
||
copy(newSlice, slice)
|
||
slice = newSlice
|
||
}
|
||
slice = slice[0:n]
|
||
copy(slice[m:n], data)
|
||
return slice
|
||
}
|
||
```
|
||
|
||
`func copy(dst, src []T) int` copy 方法将类型为 T 的 slice 从源地址 src 拷贝到目标地址 dst,覆盖 dst 的相关元素,并且返回拷贝的元素个数。源地址和目标地址可能会有重叠。拷贝个数是 src 和 dst 的长度最小值。如果 src 是字符串那么元素类型就是 byte。如果你还想继续使用 src,在拷贝技术后执行 src =dst。
|
||
|
||
**练习 7.9**
|
||
|
||
给定 `slice s[]int` 和一个 int 类型的因子,扩展 s 使其长度为 `len(s) * factor`。
|
||
|
||
**练习 7.10**
|
||
|
||
用顺序函数过滤容器:s 是前 10 个整形的 slice。构造一个函数 Filter,第一个参数是 s,第二个参数是一个 `fn func(int) bool`,返回满足函数 fn 的元素 slice。通过 fn 测试方法测试当整型值是偶数时的情况。
|
||
|
||
**练习 7.11**
|
||
|
||
写一个函数 InsertStringSlice 将 slice 插入到另一个 slice 的指定位置。
|
||
|
||
**练习 7.12**
|
||
|
||
写一个函数 RemoveStringSlice 将从 start 到 end 索引的元素从 slice 中移除。
|
||
|
||
## 链接
|
||
|
||
- [目录](directory.md)
|
||
- 上一节:[切片重组](07.4.md)
|
||
- 下一节:[字符串、数组和切片的应用](07.6.md)
|