婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > go特性之數組與切片的問題

go特性之數組與切片的問題

熱門標簽:官渡電銷外呼管理系統怎么收費 貴州電話智能外呼系統 赤峰電銷 地圖區域圖標注后導出 杭州人工智能電銷機器人費用 谷歌美發店地圖標注 江蘇呼叫中心外呼系統有效果嗎 400開頭電話怎樣申請 利用地圖標注位置

數組:
復制傳遞(不要按照c/c++的方式去理解,c/c++中數組是引用傳遞),定長

切片:
引用傳遞,底層實現是3個字段 array(數組) + len(長度) +cap(容量)

go/src/runtime/slice.go slice結構定義:
type slice struct {
	array unsafe.Pointer
	len  int
	cap  int
}

要特別注意的是,切片的引用傳遞指的是切片傳遞時,切片的array字段是引用傳遞的,len和cap字段依然是賦值傳遞。
寫個偽代碼:

type Slice struct {
	Array []interface{}
	Len int
	Cap int
}

func fake() {
	slice1 := Slice{
		Array: 指向一塊連續內存的定長數組,
		Len: 0,
		Cap: 4
	}
	
	slice2 := slice1 // 這一行相當于如下:
	
	slice2 := Slice{}
	slice2.Array = slice1.Array // 指向同一塊內存,所以說切片是引用傳遞
	slice2.Len = slice1.Len // len字段被復制了
	slice2.Cap = slice2.Cap // cap字段被復制了

    // 后續如果觸發了任一slice的array重新分配內存,另一個slice都是不知道的
	// 已經修改任一slice的len和cap,另一個slice也是不知道的
}

最后總結題

//
//輸出結果:
//array1: [1 2 3] array2 [100 2 3]
//slice1: [100 2 3] slice2 [100 2 3]
//
func TestSlice1(t *testing.T) {
	// 數組是賦值傳遞
	array1 := [3]int{1,2,3}

	// 這里array1復制了一份,array2和array1已經不是同一份數據了
	// 所以對數組array1,array2的修改是互不影響的
	array2 := array1
	array2[0] = 100
	fmt.Println("array1:", array1, "array2", array2)



	// 切片是引用傳遞
	slice1 := make([]int, 0)
	slice1 = append(slice1, 1, 2, 3)

	// slice2和slice1引用的同一份數據,所以slice2對已有元素的修改,會影響到slice1
	// 這里有個細節需要注意,往下面TestSlice2繼續看
	slice2 := slice1
	slice2[0] = 100
	fmt.Println("slice1:", slice1, "slice2", slice2)
}

/*
輸出結果
slice1: [1 2 3] slice2 [1 2 3 4]
slice1: [1 2 3] slice2 [1 2 3 4 5]
slice1: [1 2 3] slice2 [100 2 3 4 5]
 */
func TestSlice2(t *testing.T) {
	// 切片是引用傳遞
	slice1 := make([]int, 0, 4) // 容量是4
	slice1 = append(slice1, 1, 2, 3)

	// slice2和slice1引用的同一份數據,所以slice2對元素的修改,會影響到slice1
	// 特別要注意的是,這里說的引用同一份數據,實際上是指的slice1和slice2內部的ptr指向了同一個數組
	// 但是slice1和slice2結構中的len和cap是復制傳遞的
	slice2 := slice1
	// 添加第4個元素,容量足夠,不會觸發內部ptr數組重新分配
	slice2 = append(slice2, 4)
	fmt.Println("slice1:", slice1, "slice2", slice2)

	// 添加第5個元素,容量不足,slice2.ptr重新分配內存,此時slice2.ptr和slice1.ptr已經不是同一份內存了
	slice2 = append(slice2, 5)
	fmt.Println("slice1:", slice1, "slice2", slice2)

	// 所以這里slice2對已有元素的修改,不會影響到slice1了
	slice2[0] = 100
	fmt.Println("slice1:", slice1, "slice2", slice2)
}

到此這篇關于go特性之數組與切片的問題的文章就介紹到這了,更多相關go數組切片內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 分析MongoDB和MySQL各自的關鍵特性、差別和優勢
  • golang1.16新特性速覽(推薦)
  • django 中QuerySet特性功能詳解
  • MongoDB的基本特性與內部構造的講解
  • Django 2.0版本的新特性搶先看!
  • golang中defer的關鍵特性示例詳解
  • Go語言區別于其他語言的特性

標簽:河池 保定 黔西 武漢 宜春 松原 泰安 鷹潭

巨人網絡通訊聲明:本文標題《go特性之數組與切片的問題》,本文關鍵詞  特性,之,數組,與,切片,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《go特性之數組與切片的問題》相關的同類信息!
  • 本頁收集關于go特性之數組與切片的問題的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 云阳县| 麻阳| 安仁县| 佛学| 宿迁市| 东阳市| 改则县| 股票| 长垣县| 壤塘县| 开化县| 台南县| 龙江县| 翁牛特旗| 加查县| 抚顺县| 周宁县| 云南省| 措美县| 福清市| 丰城市| 开阳县| 丰顺县| 大连市| 临夏县| 资溪县| 铅山县| 容城县| 商城县| 郴州市| 益阳市| 全椒县| 手机| 和田市| 沽源县| 凤庆县| 富源县| 晋中市| 蒙自县| 景洪市| 昌吉市|