内容简介:注:本文是对在Go语言中,函数参数是值传递。使用slice作为函数参数时,函数获取到的是slice的副本:一个指针,指向底层数组的起始地址,同时带有slice的长度和容量。既然各位熟知数据存储的内存的地址,现在可以对切片数据进行修改。让我们看看下面的例子:In Go, the function parameters are passed by value. With respect to use slice as a function argument, that means the function wi
注:本文是对 golang-101-hacks 中文翻译。
在 Go 语言中,函数参数是值传递。使用slice作为函数参数时,函数获取到的是slice的副本:一个指针,指向底层数组的起始地址,同时带有slice的长度和容量。既然各位熟知数据存储的内存的地址,现在可以对切片数据进行修改。让我们看看下面的例子:
In Go, the function parameters are passed by value. With respect to use slice as a function argument, that means the function will get the copies of the slice: a pointer which points to the starting address of the underlying array, accompanied by the length and capacity of the slice. Oh boy! Since you know the address of the memory which is used to store the data, you can tweak the slice now. Let's see the following example:
package main import ( "fmt" ) func modifyValue(s []int) { s[1] = 3 fmt.Printf("In modifyValue: s is %v\n", s) } func main() { s := []int{1, 2} fmt.Printf("In main, before modifyValue: s is %v\n", s) modifyValue(s) fmt.Printf("In main, after modifyValue: s is %v\n", s) }
运行结果如下
In main, before modifyValue: s is [1 2] In modifyValue: s is [1 3] In main, after modifyValue: s is [1 3]
由此可见,执行modifyValue函数,切片s的元素发生了变化。尽管modifyValue函数只是操作slice的副本,但是任然改变了切片的数据元素,看另一个例子:
You can see, after running modifyValue function, the content of slice s is changed. Although the modifyValue function just gets a copy of the memory address of slice's underlying array, it is enough!
See another example:
package main import ( "fmt" ) func addValue(s []int) { s = append(s, 3) fmt.Printf("In addValue: s is %v\n", s) } func main() { s := []int{1, 2} fmt.Printf("In main, before addValue: s is %v\n", s) addValue(s) fmt.Printf("In main, after addValue: s is %v\n", s) }
The result is like this:
In main, before addValue: s is [1 2] In addValue: s is [1 2 3] In main, after addValue: s is [1 2]
而这一次,addValue函数并没有修改main函数中的切片s的元素。这是因为它只是操作切片s的副本,而不是切片s本身。所以如果真的想让函数改变切片的内容,可以传递切片的地址:
This time, the addValue function doesn't take effect on the s slice in main function. That's because it just manipulate the copy of the s, not the "real" s.
So if you really want the function to change the content of a slice, you can pass the address of the slice:
package main import ( "fmt" ) func addValue(s *[]int) { *s = append(*s, 3) fmt.Printf("In addValue: s is %v\n", s) } func main() { s := []int{1, 2} fmt.Printf("In main, before addValue: s is %v\n", s) addValue(&s) fmt.Printf("In main, after addValue: s is %v\n", s) }
运行结果如下
In main, before addValue: s is [1 2] In addValue: s is &[1 2 3] In main, after addValue: s is [1 2 3]
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- Go 语言函数式编程系列教程(九) —— 数据类型篇:数组切片的创建和遍历
- Go 语言函数式编程系列教程(十) —— 数据类型篇:在数组切片中动态增删元素
- GOLAMG-5 type 不同于C/C++ typedef,切片底层是指针域的函数指针
- Go切片
- golang 数组和切片
- golang 切片小结
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Programming From The Ground Up
Jonathan Bartlett / Bartlett Publishing / 2004-07-31 / USD 34.95
Programming from the Ground Up is an introduction to programming using assembly language on the Linux platform for x86 machines. It is a great book for novices who are just learning to program as wel......一起来看看 《Programming From The Ground Up》 这本书的介绍吧!