golang 复制切片
本篇文章介绍如何在 go 语言中复制切片。
在 golang 中复制切片
在 go 语言中复制切片可以通过不同的方法来实现。 copy()
和 append()
方法通常用于此目的,其中 copy()
获取给定切片的深拷贝,而 append()
方法将切片的内容复制到空切片中。
在 go 中使用 copy() 方法复制一个切片
copy()
方法被认为是在 golang 中复制切片的最佳方法,因为它创建了切片的深层副本。
语法:
func copy(destination, source []type) int
目标是复制的切片,源是我们从中复制的切片。 该函数返回复制切片的元素数。
代码示例:
package main
import "fmt"
func main() {
// create slices
demoslice1 := []string{"jiyik1", "jiyik2", "jiyik3", "jiyik4", "jiyik5", "jiyik6", "jiyik7", "jiyik8"}
dstslice1 := make([]string, len(demoslice1))
var demoslice2 []string
dstslice2 := []string{"tutorials1"}
demoslice3 := []string{"jiyik9", "jiyik10"}
dstslice3 := []string{"tutorials1", "tutorials2"}
demoslice4 := []string{"jiyik11", "jiyik13", "jiyik14", "jiyik15"}
dstslice4 := []string{"tutorials1", "tutorials2", "tutorials3"}
// slices before copying
fmt.println("source slice1 is :", demoslice1)
fmt.println("destination slice1 is :", dstslice1)
fmt.println("source slice2 is :", demoslice2)
fmt.println("destination slice2 is :", dstslice2)
fmt.println("source slice3 is :", demoslice3)
fmt.println("destination slice3 is :", dstslice3)
fmt.println("source slice4 is :", demoslice4)
fmt.println("destination slice1 is :", dstslice4)
// copy the slices
copiedslice1 := copy(dstslice1, demoslice1)
fmt.println("\n destination slice 1 after copying:", dstslice1)
fmt.println("total number of elements copied:", copiedslice1)
copiedslice2 := copy(dstslice2, demoslice2)
fmt.println("\n destination slice 2 after copying:", dstslice2)
fmt.println("total number of elements copied:", copiedslice2)
copiedslice3 := copy(dstslice3, demoslice3)
fmt.println("\n destination slice 3 after copying:", dstslice3)
fmt.println("total number of elements copied:", copiedslice3)
copiedslice4 := copy(dstslice4, demoslice4)
fmt.println("\n destination slice 4 after copying:", dstslice4)
fmt.println("total number of elements copied:", copiedslice4)
}
上面的代码创建了四个源切片和四个具有不同成员或具有相同长度的空切片的目标切片。
输出:
source slice1 is : [jiyik1 jiyik2 jiyik3 jiyik4 jiyik5 jiyik6 jiyik7 jiyik8]
destination slice1 is : [ ]
source slice2 is : []
destination slice2 is : [tutorials1]
source slice3 is : [jiyik9 jiyik10]
destination slice3 is : [tutorials1 tutorials2]
source slice4 is : [jiyik11 jiyik13 jiyik14 jiyik15]
destination slice1 is : [tutorials1 tutorials2 tutorials3]
destination slice 1 after copying: [jiyik1 jiyik2 jiyik3 jiyik4 jiyik5 jiyik6 jiyik7 jiyik8]
total number of elements copied: 8
destination slice 2 after copying: [tutorials1]
total number of elements copied: 0
destination slice 3 after copying: [jiyik9 jiyik10]
total number of elements copied: 2
destination slice 4 after copying: [jiyik11 jiyik13 jiyik14]
total number of elements copied: 3
在 go 中使用 append() 方法复制切片
append
方法会将给定切片的内容附加到目标切片。
语法:
func destination = append(destination, source...)
append 方法会将源切片的内容复制到空的目标切片或具有成员的切片。 它会返回包含先前成员和复制成员的切片,这与复制方法不同。
代码示例:
package main
import "fmt"
func main() {
// create slices
demoslice1 := []string{"jiyik1", "jiyik2", "jiyik3", "jiyik4", "jiyik5", "jiyik6", "jiyik7", "jiyik8"}
var dstslice1 []string
var demoslice2 []string
dstslice2 := []string{"tutorials1"}
demoslice3 := []string{"jiyik9", "jiyik10"}
dstslice3 := []string{"tutorials1", "tutorials2"}
demoslice4 := []string{"jiyik11", "jiyik13", "jiyik14", "jiyik15"}
dstslice4 := []string{"tutorials1", "tutorials2", "tutorials3"}
// slices before copying
fmt.println("source slice1 is :", demoslice1)
fmt.println("destination slice1 is :", dstslice1)
fmt.println("source slice2 is :", demoslice2)
fmt.println("destination slice2 is :", dstslice2)
fmt.println("source slice3 is :", demoslice3)
fmt.println("destination slice3 is :", dstslice3)
fmt.println("source slice4 is :", demoslice4)
fmt.println("destination slice1 is :", dstslice4)
// copy the slices
copiedslice1 := append(dstslice1, demoslice1...)
fmt.println("the copied slice 1 after copying: ", copiedslice1)
copiedslice2 := append(dstslice2, demoslice2...)
fmt.println("the copied slice 2 after copying: ", copiedslice2)
copiedslice3 := append(dstslice3, demoslice3...)
fmt.println("the copies slice 3 after copying: ", copiedslice3)
copiedslice4 := append(dstslice4, demoslice4...)
fmt.println("the copied slice 4 after copying: ", copiedslice4)
}
上面的代码片段会将一个切片的内容复制到另一个切片。
输出:
source slice1 is : [jiyik1 jiyik2 jiyik3 jiyik4 jiyik5 jiyik6 jiyik7 jiyik8]
destination slice1 is : []
source slice2 is : []
destination slice2 is : [tutorials1]
source slice3 is : [jiyik9 jiyik10]
destination slice3 is : [tutorials1 tutorials2]
source slice4 is : [jiyik11 jiyik13 jiyik14 jiyik15]
destination slice1 is : [tutorials1 tutorials2 tutorials3]
the copied slice 1 after copying: [jiyik1 jiyik2 jiyik3 jiyik4 jiyik5 jiyik6 jiyik7 jiyik8]
the copied slice 2 after copying: [tutorials1]
the copies slice 3 after copying: [tutorials1 tutorials2 jiyik9 jiyik10]
the copied slice 4 after copying: [tutorials1 tutorials2 tutorials3 jiyik11 jiyik13 jiyik14 jiyik15]
在 go 中使用赋值方法复制一个切片
分配方法 copy 是切片的浅表副本,我们将源切片分配给目标切片。
代码示例:
package main
import "fmt"
func main() {
// create slices
demoslice1 := []string{"jiyik1", "jiyik2", "jiyik3", "jiyik4", "jiyik5", "jiyik6", "jiyik7", "jiyik8"}
var demoslice2 []string
demoslice3 := []string{"jiyik9", "jiyik10"}
demoslice4 := []string{"jiyik11", "jiyik13", "jiyik14", "jiyik15"}
// slices after copying
fmt.println("source slice1 is :", demoslice1)
dstslice1 := demoslice1
fmt.println("destination slice1 is :", dstslice1)
fmt.println("source slice2 is :", demoslice2)
dstslice2 := demoslice2
fmt.println("destination slice2 is :", dstslice2)
fmt.println("source slice3 is :", demoslice3)
dstslice3 := demoslice3
fmt.println("destination slice3 is :", dstslice3)
fmt.println("source slice4 is :", demoslice4)
dstslice4 := demoslice4
fmt.println("destination slice1 is :", dstslice4)
}
如我们所见,我们将切片分配给其他切片。 这是一种肤浅的方法,并没有被广泛使用,因为当我们修改复制的内容时,原始切片也会发生变化。
输出:
source slice1 is : [jiyik1 jiyik2 jiyik3 jiyik4 jiyik5 jiyik6 jiyik7 jiyik8]
destination slice1 is : [jiyik1 jiyik2 jiyik3 jiyik4 jiyik5 jiyik6 jiyik7 jiyik8]
source slice2 is : []
destination slice2 is : []
source slice3 is : [jiyik9 jiyik10]
destination slice3 is : [jiyik9 jiyik10]
source slice4 is : [jiyik11 jiyik13 jiyik14 jiyik15]
destination slice1 is : [jiyik11 jiyik13 jiyik14 jiyik15]
转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处
本文地址:
相关文章
发布时间:2023/04/27 浏览次数:101 分类:
-
本篇文章介绍了在 golang 的 html 模板中使用 if-else 和 switch 循环。因此,只要输出是 html,就应该始终使用 html 模板包而不是文本模板。
发布时间:2023/04/27 浏览次数:184 分类:
-
本篇文章介绍 nil 在 golang 中的含义,nil 是 go 编程语言中的零值,是众所周知且重要的预定义标识符。
golang 中的 lambda 表达式
发布时间:2023/04/27 浏览次数:691 分类:
-
本篇文章介绍如何在 golang 中创建 lambda 表达式。lambda 表达式似乎不存在于 golang 中。 函数文字、lambda 函数或闭包是匿名函数的另一个名称。
发布时间:2023/04/27 浏览次数:136 分类:
-
当我们尝试生成对象的副本时,深层副本会准确复制原始对象的所有字段。 此外,如果它有任何对象作为字段,也会制作这些对象的副本。本篇文章介绍如何在 golang 中进行深度复制。
发布时间:2023/04/27 浏览次数:104 分类:
-
像错误一样,panic 发生在运行时。 换句话说,当您的 go 程序中出现意外情况导致执行终止时,就会发生 panics。让我们看一些例子来捕捉 golang 中的panics。
go 中的日志级别
发布时间:2023/04/27 浏览次数:585 分类:
-
本篇文章介绍如何在 golang 中创建和使用日志级别。go 中的日志级别。golang提供了一个日志包,名为log,是一个简单的日志包。 这个包不提供分级日志; 如果我们想要分级日志记录,我们必须
在 go 中使用断言
发布时间:2023/04/27 浏览次数:585 分类:
-
本篇文章介绍了 assert 在 golang 中的使用。在 go 语言中使用断言:golang 不提供对断言的任何内置支持,但我们可以使用来自 testify api 的广泛使用的第三方包断言。
go 中的随机数生成
发布时间:2023/04/27 浏览次数:206 分类:
-
本篇文章介绍如何在 go 语言中使用随机数生成功能。go 中的随机数生成 go 语言为随机数生成功能提供内置支持。 内置包 math 有方法 rand(),用于随机数生成。