引數傳遞是指在程式的傳遞過程中,實際引數就會將引數值傳遞給相應的形式引數,然後在函式中實現對資料處理和返回的過程,下面這篇文章主要給大家介紹了關於Golang中引數傳遞的相關資料,需要的朋友可以參考下。
前言
本文主要給大家介紹了關於Golang引數傳遞的相關內容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。
關於引數傳遞,Golang文件中有這麼一句:
after they are evaluated, the parameters of the call are passed by value to the
function and the called function begins execution.
函式呼叫引數均為值傳遞,不是指標傳遞或引用傳遞。經測試引申出來,當引數變數為指標或隱式指標型別,引數傳遞方式也是傳值(指標本身的copy)
Slice是最常用的資料結構之一,下面以Slice為例,解釋Golang的引數傳遞機制。
Slice資料結構如下:
示例程式碼:
package main import "fmt" func main(){ slice := make([]int, 3, 5) fmt.Println("before:", slice) changeSliceMember(slice) fmt.Println("after:", slice) } func changeSliceMember(slice []int) { if len(slice) > 1 { slice[0] = 9 } }
函式執行結果為:
befor:[0 0 0] after:[9 0 0]
解釋:
從資料結構圖中可看出,Slice可以理解成結構體型別,包含底層陣列首元素地址、陣列len、容量三個欄位,slice物件在引數傳值過程中,把三個欄位的值傳遞過去了,實際上changeSliceMember函式內slice在記憶體中的地址和main中的slice記憶體地址不一樣,只是欄位值是一樣的,而第一個欄位Pointer的值就是底層陣列首元素地址,因此可以直接改變元素內容
可以與下面程式碼做對比,理解:
package main func main() { value := new(int) modifyFunc(value) println("main:", value) } func modifyFunc(value *int) { value = nil println("modifyFunc:", value) }
執行結果:
modifyFunc: 0x0 main: 0xc820049f30
可以看出,即使傳值為指標,仍未改變變數value在main中的值,因為modifyFunc中value的值為指標,和main中的value值一樣,但是倆物件本身是兩個物件,讀者可以細細體會。
引數傳遞是指在程式的傳遞過程中,實際引數就會將引數值傳遞給相應的形式引數,然後在函式中實現對資料處理和返回的過程,下面這篇文章主要給大家介紹了關於Golang中引數傳遞的相關資料,需要的朋友可以參考下。
前言
本文主要給大家介紹了關於Golang引數傳遞的相關內容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。
關於引數傳遞,Golang文件中有這麼一句:
after they are evaluated, the parameters of the call are passed by value to the
function and the called function begins execution.
函式呼叫引數均為值傳遞,不是指標傳遞或引用傳遞。經測試引申出來,當引數變數為指標或隱式指標型別,引數傳遞方式也是傳值(指標本身的copy)
Slice是最常用的資料結構之一,下面以Slice為例,解釋Golang的引數傳遞機制。
Slice資料結構如下:
示例程式碼:
package main import "fmt" func main(){ slice := make([]int, 3, 5) fmt.Println("before:", slice) changeSliceMember(slice) fmt.Println("after:", slice) } func changeSliceMember(slice []int) { if len(slice) > 1 { slice[0] = 9 } }
函式執行結果為:
befor:[0 0 0] after:[9 0 0]
解釋:
從資料結構圖中可看出,Slice可以理解成結構體型別,包含底層陣列首元素地址、陣列len、容量三個欄位,slice物件在引數傳值過程中,把三個欄位的值傳遞過去了,實際上changeSliceMember函式內slice在記憶體中的地址和main中的slice記憶體地址不一樣,只是欄位值是一樣的,而第一個欄位Pointer的值就是底層陣列首元素地址,因此可以直接改變元素內容
可以與下面程式碼做對比,理解:
package main func main() { value := new(int) modifyFunc(value) println("main:", value) } func modifyFunc(value *int) { value = nil println("modifyFunc:", value) }
執行結果:
modifyFunc: 0x0 main: 0xc820049f30
可以看出,即使傳值為指標,仍未改變變數value在main中的值,因為modifyFunc中value的值為指標,和main中的value值一樣,但是倆物件本身是兩個物件,讀者可以細細體會。