Go xmas2020 全英課程 05 學習筆記、Arrays, Slices, and Maps

来源:https://www.cnblogs.com/linxiaoxu/archive/2022/04/02/16090017.html
-Advertisement-
Play Games

05-Arrays, Slices, and Maps、 In memory、 Array、 Slice、 fence post error、 Compare Array and Slice 、 Map、 Built in functi... ...


課程地址 go-class-slides/xmas-2020 at trunk · matt4biz/go-class-slides (github.com)

主講老師 Matt Holiday

image-20220401081031592

05-Arrays, Slices, and Maps

In memory

image-20220402042140132

string、array、slice 在記憶體中是連續存儲的,map不是連續存儲的。


Array

image-20220402042243076

在創建數組的時候需要指定大小,如果不指定需要使用 ... ,圖中 a、b 將是固定的 24 位元組對象(int在64位操作系統上預設為int64),一旦設定不能改變。

d=b 中,由於數組只是一塊記憶體,並不是像字元串那樣的描述符,我們只是物理地複製了位元組。當數組大小不一致時,無法進行拷貝複製。


Slice

image-20220402042810564

切片有描述符,指向一個特定的記憶體地址。它的工作方式類似於字元串的工作方式。

切片描述符包含 data、len、capacity。

append 方法需要把返回值重新賦給 a,假設 a 指向的記憶體區域已經滿了,再添加元素就要開闢新的更大的記憶體區域存放。

a=b 表示 b 描述符的內容被拷貝到 a 描述符中。

e:=a 新建一個描述符,內容與 a 描述符內的一致。


切片可以被切片(截取)操作,就像從字元串(前面的os.Args[1:])中取出切片,從切片數組切片等。

package main

import "fmt"

func main() {
	t := []byte("string")

	fmt.Println(len(t), t)
	fmt.Println(t[2])
	fmt.Println(t[:2])
	fmt.Println(t[2:])
	fmt.Println(t[3:5], len(t[3:5]))
}
6 [115 116 114 105 110 103]
114
[115 116]
[114 105 110 103]
[105 110] 2

fence post error

image-20220402043131288

柵欄柱錯誤:假設我有三個柵欄部分,我必須有四個柵欄在他們旁邊將它們固定住。(不懂直接看圖)


Compare Array、Slice

image-20220402045248221

切片可以是任意長度,而且大部分 Go 的標準庫使用切片作為參數。

切片是不能進行比較的,想進行比較可以使用數組。這也導致切片不能作為 Map Key。


數組可以作為一些演算法必備的數組。大小固定,值不改變。近似於偽常量。註意,不能添加 const 常量關鍵字,只有數字,字元串,布爾值可以作為常量。

image-20220402045647614


Example

image-20220402045941511

a[0]=4 因為 a 只是 w 的值拷貝(數組),所以修改後 w 並沒有被修改。

b[0]=3 將會使 x 修改,因為兩者 data 都指向同一個記憶體地址。(但是要註意,這是值拷貝,如果添加元素過多,會導致 b 的 data 指針使用新的記憶體地址而 x 還是指向原來的)

copy(c, b) 函數不會因為切片大小不同出錯,會儘可能把 b 切片中的元素拷貝到 c 中。


我們可以對數組切片如 z := a[0:2] z 將是一個切片,指向 a 的前兩個元素,go 會自動提供數組來保存。


Map

image-20220402050751005

假設要計算一個文件中不同單詞出現的次數,就可以使用 Maps。是一個 Hash table。

m 是一個描述符,但是整體為空。 p 的 data 指針指向一個哈希表。


image-20220402051658526

map 與 map 間不能進行比較,只能進行 nil 比較。

可以查看 map 的長度,不能查看 map 的容量。


image-20220402051820579

可以通過獲取第二個參數判斷鍵值對是否存在。


Built in functions

image-20220402052141191

Make nil useful

image-20220402052630469

由於 len、cap、range 這些內建函數是安全的,我們不需要 if 判斷 nil 就可以直接使用。

range 將會跳過 nil、empty 的迴圈對象。


Quote

image-20220402053526148

一種不影響你思考編程的方式的語言是不值得瞭解的


Practice

編寫一個段落單詞計數器,輸出前三個出現次數最多的單詞。

main.go

package main

import (
	"bufio"
	"fmt"
	"os"
	"sort"
)

func main() {
	scan := bufio.NewScanner(os.Stdin)
	words := make(map[string]int)

	// ^ 預設是按行讀取,所以手動指定按單詞讀取
	scan.Split(bufio.ScanWords)

	for scan.Scan() {
		words[scan.Text()]++
	}

	fmt.Println(len(words), "unique words")

	type kv struct {
		key string
		val int
	}

	var ss []kv

	for k, v := range words {
		ss = append(ss, kv{k, v})
	}

	// ^ 直接修改原切片
	sort.Slice(ss, func(i, j int) bool {
		return ss[i].val > ss[j].val
	})

	for _, s := range ss[:3] {
		fmt.Println(s.key, "appears", s.val, "times")
	}
}

scan.Split(bufio.ScanWords) Scanner 預設是按行讀取,所以手動指定按單詞讀取。

kv{k, v} 結構體的初始化

sort.Slice 函數直接修改原切片,傳入的函數在 return 前面的元素排在切片的前面。如左>右,則大的元素在切片最前面,屬於降序排序。


test.txt

matt went to greece
where did matt go
alan went to rome
matt didn't go there

第一行是空行是有原因的,這是 BOM頭(Byte Order Mark) 導致的,具體請看另一篇文章

重定向管道流讀取TXT文本第一次讀取為""空字元串 - 小能日記 - 博客園 (cnblogs.com)


result

cat test.txt | go run .

12 unique words
matt appears 3 times
to appears 2 times
go appears 2 times

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 場景:針對於分散式併發環境,易出現編碼生成重覆問題 方案特點:串列操作可避免阻塞加鎖,處理效率更高 具體解決方案 ...
  • 怎麼能不懷念呢?到現在依稀記得高考時的自己,輾轉失眠、挑燈夜戰、奮筆勤書。那時候拼命的自己真的很好,好想懷念高考,加爬一下自己19年的高考數據吧。 對於像作者一樣已經工作的“上班族”來說,6月7號到9號三天無疑是興奮到飛起的,終於迎來了令人愉悅的端午假期: 然而有那麼一群人,將在端午節日之際迎來人生 ...
  • 前言 以往的人臉識別主要是包括人臉圖像採集、人臉識別預處理、身份確認、身份查找等技術和系統。現在人臉識別已經慢慢延伸到了ADAS中的駕駛員檢測、行人跟蹤、甚至到了動態物體的跟蹤。 由此可以看出,人臉識別系統已經由簡單的圖像處理髮展到了視頻實時處理。而且演算法已經由以前的Adaboots、PCA等傳統的 ...
  • 1 基礎知識 單點登錄機制(SSO)允許用戶登錄應用程式一次,並訪問所有相關的系統,而不需要單獨登錄它們。 由於 SSO,用戶只需登錄一次即可使用服務,並自動登錄到所有相關應用程式。SSO 消除了單獨登錄它們的需要。此外,用戶不需要存儲或記住多個憑據。 單點登錄僅與身份驗證過程相關。它的任務是驗證用 ...
  • 昨天,在發佈了《Spring官宣承認網傳大漏洞,並提供解決方案》之後。群里就有幾個小伙伴問了這樣的問題:**我們的Spring版本比較老,該怎麼辦?**這是一個好問題,所以DD今天單獨拿出來說說。 這次的RCE漏洞宣佈之後,官方給出的主要解決方案是升級版本,但只有Spring 5.2、5.3和Spr ...
  • 一、概要 1、來源 積木報表版本號:1.4.2 2、異常現象 導出Excel失敗 3、異常棧: com.googlecode.aviator.exception.CompileExpressionErrorException: Blank expression at com.googlecode.a ...
  • 前言 怎麼樣使用Python提高自己的工作效率,今天就給大家分享這個吧。我們經常用pandas讀入讀寫excel文件,經常會遇到一個excel文件里存在多個sheet文件,這個時候,就需要一次性讀取多個sheet的數據並做相應的數據分析或數據處理,最後再寫入新的excel文件(同樣是多個sheet) ...
  • 博客推行版本更新,成果積累制度,已經寫過的博客還會再次更新,不斷地琢磨,高質量高數量都是要追求的,工匠精神是學習必不可少的精神。因此,大家有何建議歡迎在評論區踴躍發言,你們的支持是我最大的動力,你們敢投,我就敢肝 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...