每次學習并整理一個Golang的知識點,每天進步一點點。今天學習下go中的一個知識點:map元素查找
日省吾身
1.下面代碼中 A B 兩處應該怎么修改才能順利編譯?
func main() { var m map[string]int //A m["a"] = 1 if v := m["b"]; v != nil { //B fmt.Println(v) }}
2.寫出下面代碼片段的輸出結果?
func main() {s := [3]string{"a", "b", "c"}s1 := s[:0]s2 := s[:2]s3 := s[1:2:cap(s)]fmt.Println("s1:", len(s1), cap(s1))fmt.Println("s2:", len(s2), cap(s2))fmt.Println("s3:", len(s3), cap(s3))}
思考后看下方答案…

答疑解惑
參考答案:
1. 原程序編譯報錯,改進后的程序示例如下:
func main() { // var m map[string]int //A m := make(map[string]int) //A改進 m["a"] = 1 // if v := m["b"]; v != nil { //B if v, ok := m["b"]; ok { //B改進 fmt.Println(v) }
知識點:map
- 在 A 處,只進行了map的聲明,沒有分配內存空間,即沒有初始化,當前 m 是一個 nil map,不能直接賦值;go中推薦使用內置函數make()或字面量的方式進行map的初始化;
- 在 B 處,從map中查找一個特定的值,推薦使用改進后的寫法; 判斷是否找到了特定的值,不需要檢查取到的值是否為nil,只需查看第二個返回值ok;它是一個bool型,返回true表示找到了對應的數據;配合 := 操作符,減少代碼冗余,看起來清晰易懂;
2. 程序的輸出結果為:
s1: 0 3s2: 2 3s3: 1 2
知識點: 切片的創建
- 基于數組切片,可以使用操作符創建新的切片,形如s[n:l:c],n是偏移的起始位置,l是偏移的長度結束,c是偏移的容量結束位置;l-n 就是新切片的長度, c-n 就是新切片的容量;如果n省略,默認為0;
- 有意思的是,n、l和c并不是當前切片的索引,所以l是可以超出當前切片的長度的,但不能超出當前切片的容量;比如假設oldSlice只有5個元素,但容量是10;newSlice卻可以基于oldSlice的前7個元素創建,newSlice中超出oldSlice的部分都會填上0;
以上,你做對了嗎?
其他相關答案或補充知識點,歡迎在評論區留言補充!
下期提問
- 判斷下面代碼片段的輸出結果?
func incrementA() int {var n intdefer func() {n++}()return n}func incrementB() (m int) {defer func() {m++}()return m}func main() {fmt.Println(incrementA())fmt.Println(incrementB())}
- A. 0 0
- B. 0 1
- C. 1 0
- D. 1 1
答案及解析將在下期文章中給出,歡迎大家在評論區寫出你的答案;獨樂樂不如眾樂樂,歡迎交流學習,互相進步。
歡迎轉發和評論。更多優質原創文章,歡迎關注微信公眾號“IYue愛月”。