图解 Slice *** 作

图解 Slice  *** 作,第1张

概述via:https://ueokande.github.io/go-slice-tricks/作者:ueokande较早使用Go的同学,应该有了解过container/vector包,不过后面引进了append(),包里的很多函数都可以使用append()和copy()代替,Go官方就把这个包删除了。为此,Go官方还在GithubWiki上写了一份文档,关于如何

via:
https://ueokande.github.io/go-slice-tricks/
作者:ueokande

较早使用 Go 的同学,应该有了解过 container/vector 包,不过后面引进了 append(),包里的很多函数都可以使用 append() 和 copy() 代替,Go 官方就把这个包删除了。

为此,Go 官方还在 Github Wiki 上写了一份文档,关于如何使用 append() 和 copy() 代替 vector 包提供的方法,原文地址:

https://github.com/golang/go/wiki/SliceTricks

针对这份手册,ueokande 做了一份图解版的,看着生动形象,帮忙大家记忆,分享给大家。

 

原文如下:


00. 

a = append(a, b...)
01. 

1.
b = make([]T, len(a))
copy(b, a)

2.
b = append([]T(nil), a...)

3.
b = append(a[:0:0], a...)
02. 

a = append(a[:i], a[j:]...)
03. 

copy(a[i:], a[j:])
for k, n := len(a)-j+i, len(a); k < n; k++ {
 a[k] = nil // or the zero value of T
}
a = a[:len(a)-j+i]
04. 

1.
a = append(a[:i], a[i+1:]...)

2.
a = a[:i+copy(a[i:], a[i+1:])]
05. 

if i < len(a)-1 {
  copy(a[i:], a[i+1:])
}
a[len(a)-1] = nil // or the zero value of T
a = a[:len(a)-1]
06. 

a[i] = a[len(a)-1] 
a = a[:len(a)-1]
07. 

a[i] = a[len(a)-1]
a[len(a)-1] = nil
a = a[:len(a)-1]
08. 

 

a = append(a[:i], append(make([]T, j), a[i:]...)...)
09. 

a = append(a, make([]T, j)...)
10. 

n := 0
for _, x := range a {
 if keep(x) {
  a[n] = x
  n++
 }
}
a = a[:n]
11. 

a = append(a[:i], append([]T{x}, a[i:]...)...)
12. 

a = append(a[:i], append(b, a[i:]...)...)
13. 

x, a = a[len(a)-1], a[:len(a)-1]
14. 

a = append(a, x)
15. 

x, a = a[0], a[1:]
16. 

a = append([]T{x}, a...)

 


这是持续翻译的第 17/100 篇优质文章。
如果你有想交流的话题,欢迎留言。


 

 

如果我的文章对你有所帮助,点赞、转发都是一种支持!

总结

以上是内存溢出为你收集整理的图解 Slice *** 作全部内容,希望文章能够帮你解决图解 Slice *** 作所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1211754.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存