Go語言基礎(chǔ)切片的創(chuàng)建及初始化示例詳解
概述
- 切片是一種動態(tài)數(shù)組
- 按需自動改變大小
- 與數(shù)組相比,切片的長度可以在運(yùn)行時修改
語法
一、創(chuàng)建和初始化切片
make
使用內(nèi)置函數(shù)make()創(chuàng)建切片:
var slice []type = make([]type, len, cap) //簡寫: slice := make([]type, len, cap)
字面量
var 變量名 []type
slice1:=[]string{"張三","李四"} // 長度和容量都是5個元素的字符串切片 slice2 := []int{10, 20, 30} // 長度和容量都是3個元素的整型切片
二、使用切片
賦值和切片
使用[]操作符就可以改變某個元素的,實(shí)例如下:
// 創(chuàng)建一個整型切片 // 其容量和長度都是5個元素 slice1:=[]string{"張三","李四","王五","馬六","老七"} // 改變索引為1的元素的值 slice1[1] = "小張三"
使用切片創(chuàng)建切片
// 創(chuàng)建一個整型切片 // 其長度和容量都是5個元素 slice1:=[]string{"張三","李四","王五","馬六","老七"} // 創(chuàng)建一個新切片 // 其長度為3個元素,容量為3個元素 newSlice:=slice1[2:5]
切片增長
使用append向切片增加元素,同時增加切片的長度和容量
// 創(chuàng)建一個整型切片 // 其長度和容量都是5個元素 slice1:=[]string{"張三","李四","王五","馬六","老七"} // 使用原有的容量來分配一個新元素 // 將新元素賦值為60 newSlice:=append(slice1,"我是新來的")
遍歷切片
使用 for range 迭代切片
slice1 := []string{"張三", "李四", "王五", "馬六", "老七"} for k, v := range slice1 { fmt.Println(k, v) }
使用 for 循環(huán)迭代切片
slice1 := []string{"張三", "李四", "王五", "馬六", "老七"} for i := 0; i < len(slice1); i++ { fmt.Println(i,slice1[i]) }
總結(jié)
- slice 的默認(rèn)開始位置是0,ar[:n]等價于ar[0:n]
- slice是引用類型,是一個指向數(shù)組的指針
- 不能使用 == 來判斷兩個slice 是給含有全部相同元素
- >判斷 slice 是否為空,使用 len(s) == 0 , 而不是 s == nil
總示例
package main import ( "fmt" ) func main() { //一、創(chuàng)建切片 var slice []int = make([]int, 3) fmt.Println(slice) slice1 := []string{"張三", "李四", "王五", "馬六", "老七"} fmt.Println(slice1) slice2 := []int{10, 20, 30} fmt.Println(slice2) //二、使用切片 //使用[]操作符就可以改變某個元素 slice1[1] = "小張三" fmt.Println(slice1) //使用切片創(chuàng)建切片【下標(biāo)是從0開始】 newSlice := slice1[0:2] fmt.Println(newSlice) //切片增長 newSlice = append(slice1, "我是新來的") fmt.Println(newSlice) // 使用 for range 迭代切片【k:表示下標(biāo),v表示值】 for k, v := range slice1 { fmt.Println(k, v) } // 使用 for 循環(huán)迭代切片 for i := 0; i < len(slice1); i++ { fmt.Println(i,slice1[i]) } }
示例一 兩個slice是否相等
package main import ( "fmt" "reflect" ) func main() { //兩個slice是否相等 slice1 := []string{"張三", "李四", "王五", "馬六"} slice2 := []string{"張三", "李四", "王五", "馬六"} if reflect.DeepEqual(slice1, slice2) { fmt.Println("兩個slice相等") } else { fmt.Println("兩個slice不相等") } }
示例二 兩個數(shù)字是否包含
package main import ( "fmt" "sort" "strings" ) func main() { slice1 := []string{"張三", "李四", "王五", "馬六", "老七"} fmt.Println(slice1) target := "李四" i := sort.Search(len(slice1), func(i int) bool { return slice1[i] >= target }) if strings.EqualFold(slice1[i], target) { fmt.Println(target, "存在,它的下標(biāo)是", i) } else { fmt.Println("不存在", target) } }
以上就是Go語言基礎(chǔ)切片的創(chuàng)建及初始化示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Go語言切片的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Go垃圾回收提升內(nèi)存管理效率優(yōu)化最佳實(shí)踐
這篇文章主要為大家介紹了Go垃圾回收提升內(nèi)存管理效率優(yōu)化最佳實(shí)踐,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12淺談beego默認(rèn)處理靜態(tài)文件性能低下的問題
下面小編就為大家?guī)硪黄獪\談beego默認(rèn)處理靜態(tài)文件性能低下的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-06-06Go語言LeetCode題解961在長度2N的數(shù)組中找出重復(fù)N次元素
這篇文章主要為大家介紹了Go語言LeetCode題解961在長度2N的數(shù)組中找出重復(fù)N次元素示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12