go語言多返回值 golang返回多個值

golang-redis系列——返回值助手函數(二)

從上一節(jié)的內容可知,Do() 和 Receive() 等方法的返回值,除了 error 外,是一個 interface{} 類型的返回值,因此當我們的復雜操作返回的不是基本數據類型時,就需要我們自己解析返回值,例如,當我們利用 HMGET 方法獲取一批返回值時,就需要對返回結果進行解析,具體如下:

創(chuàng)新互聯主要從事網站制作、成都做網站、網頁設計、企業(yè)做網站、公司建網站等業(yè)務。立足成都服務寧夏,10年網站建設經驗,價格優(yōu)惠、服務專業(yè),歡迎來電咨詢建站服務:028-86922220

由于返回值是多條數據,因此需要先將 reply 轉成 []interface 類型,然后在遍歷結果時在分別轉成 []uint8 (byte數組), 最后再轉成 string 類型。

隨著我們操作復雜度,數據解析的工作量也會非常大,(lua 腳本的使用,會使結果的解析更為復雜,因為可能存在多種類型的結果一起返回的情況,lua 腳本相關的內容會在下一節(jié)介紹)。

redigo 包中的返回值助手函數的存在,就是為了幫助我們完成這些枯燥繁瑣的數據解析過程。

返回值助手函數相關源碼路徑為 github.com/gomodule/redigo/redis/reply.go 提供的主要方法如下:

上述返回值助手函數的具體使用,應該依據具體的命令進行選擇。如果大家還記得上一節(jié)介紹的 Redis 基本數據類型,可能會有些疑問,對于 redis 來說,其數據據存儲本質都是 []bytes, 為什么可以解析出 Int、int64、float等類型的數據呢?

我們以 Float64() 為例進行說明,具體源碼如下:

其實,返回值助手函數是將 []byte 類型的原始數據,利用 strconv.ParseFloat(string(reply), 64) 轉換成了 float64類型,因此在我們使用過程中返回值助手函數的選擇,應該基于業(yè)務和實際存儲的數據格式為依據。我們以第一小節(jié)的示例為例,看返回值助手函數如何降低我們的工作量,具體如下:

除了使用返回值助手函數對上述固定結構的結果進行解析外,redigo 包還提供了一個 Scan()函數用于解析自定義的復雜數據結構,我們依然以上一個示例進行說明,具體示例如下:

如果返回結果為結構化切片,也可以使用 canSlice() 方法,從而簡化 loop 處理的部分,具體示例如下:

通過上述的示例,我們介紹了 scan 函數的基本用法,但是細心的同學可能會發(fā)現嗎,為什么數據寫入時,value 的類型為 []int64 但是讀取時只能按照 string 類型讀取呢。這是因為 Redis 底層存儲的數據本質都是 string 類型,。 無論是 HMSET 還是 MSET 最終都只能按照 string 類型讀取,因為其本質都是 hash 結構,不同之處僅在于 HMSET 是嵌套的 hash類型。 因此,[]int64 數據在寫入階段,就已經被自動處理為 []byte,寫入 redis 之后,len 和 類型 屬性會丟失。

如果強行按照 []int64解析將出錯:

如果 value 必須以結構化的數據存儲,那么可以提前對要寫入的數據進行編碼,例如 json、protobuf 等,取出后再進行解碼獲得原始數據。

在Go 語言中,如何正確的使用并發(fā)

今年的早些時候我們對比過了幾種native編程語言,包括D語言、Go、Rust和Vala。這里我們將分析來自Google的Go語言,看看他到底哪里跟別的語言不一樣。 Go語言比其他的很多語言都吸引我,雖然我不是Go語言的專家,但是我很樂意在這里介紹一下它的特性,下面的這些特性指引我轉向了Go語言。 快速簡單的編譯: go語言編譯的很快,事實上,他快的甚至可以作為腳本語言了。幾個使他編譯很快的原因有: 他不使用頭文件當A依賴B,B又依賴C時,那么首先會編譯C,然后是B和A;但是如果A依賴B,但是A并不直接依賴于C,而是存在依賴傳遞,這時會把所有B需要從C拿到的信息放在B的對象代碼里。這樣,當編譯A的時候,就不需要再管C了。在編譯程序時,只需將類型信息沿著依賴關系樹向上遍歷即可,如果到達樹的頂端,則只需編譯緊鄰的依賴,而不用管其它層級的依賴了。通過多返回值的錯誤處理: 現代的編程語言基本上有兩種錯誤處理辦法,例如在C語言里是使用返回值,而在Java等面向對象語言里使用異常處理返回值,因為返回值的狀態(tài)碼總是可能跟需要返回的結果有沖突。Go語言允許多返回值,從某種程度上解決了這個問題。你可以為你的函數的執(zhí)行結果狀態(tài)定義返回值,任何調用的時候都可以來檢查,很方便。簡單的組合: 可以使用interface為對象指定一些類型的成員,還可以像Java一樣給他們指定操作(行為)。例如在標準庫的io包中定義了一個Writer,就有一個帶有字節(jié)數組作為參數(輸入)一個integer值和錯誤碼作為返回值(輸出)的方法。而實現了io.Writer接口中的Write方法的類型才是實際被執(zhí)行的。這個設計能夠非常優(yōu)雅的分離代碼,還簡化了單元測試過程,例如,如果你想測試一個數據庫對象的一個方法,在傳統(tǒng)的語言中你必須創(chuàng)建一個數據庫對象,然后做很多協議初始化工作。在Go語言中,你可在接口下創(chuàng)建任何對象。簡單的并發(fā): 在Go中并發(fā)變得非常的簡單,在任何函數前方上go兩個字母,這個函數就將以他自己的go-routine(一個非常輕量級的線程)來運行,Go- routines之間通過channels來通信。我們通常會有一些需要線程同步和互斥的需求,在Go中非常簡單,Go只是啟動并發(fā)任務,各個任務之間通過channels來通信,從而協調同步和互斥。優(yōu)秀的錯誤提示: 我從沒見過別的語言有Go語言這么高的錯誤診斷質量。例如如果你的程序思索了,Go的運行時可以通知你,而且,他甚至可以告訴你是哪個線程出了問題。當然編譯錯誤也是很詳細很有用的。其他特性:Go語言還有其他非常吸引人的特性:高階函數、垃圾回收、哈希映射、可擴展的數組等等。當然了,沒有一件東西是非常完美的,Go語言的開發(fā)工具還非常缺乏,社區(qū)很小,但是這個語言的背后支持者是Google,這些問題都會一步一步的解決。當其他語言,尤其是D語言、Rust、Vala旨在簡化C++而且增加新的特性的時候,他們都覺得自己像是帶著新特性的C++。

GO語言學習系列八——GO函數(func)的聲明與使用

GO是編譯性語言,所以函數的順序是無關緊要的,為了方便閱讀,建議入口函數 main 寫在最前面,其余函數按照功能需要進行排列

GO的函數 不支持嵌套,重載和默認參數

GO的函數 支持 無需聲明變量,可變長度,多返回值,匿名,閉包等

GO的函數用 func 來聲明,且左大括號 { 不能另起一行

一個簡單的示例:

輸出為:

參數:可以傳0個或多個值來供自己用

返回:通過用 return 來進行返回

輸出為:

上面就是一個典型的多參數傳遞與多返回值

對例子的說明:

按值傳遞:是對某個變量進行復制,不能更改原變量的值

引用傳遞:相當于按指針傳遞,可以同時改變原來的值,并且消耗的內存會更少,只有4或8個字節(jié)的消耗

在上例中,返回值 (d int, e int, f int) { 是進行了命名,如果不想命名可以寫成 (int,int,int){ ,返回的結果都是一樣的,但要注意:

當返回了多個值,我們某些變量不想要,或實際用不到,我們可以使用 _ 來補位,例如上例的返回我們可以寫成 d,_,f := test(a,b,c) ,我們不想要中間的返回值,可以以這種形式來舍棄掉

在參數后面以 變量 ... type 這種形式的,我們就要以判斷出這是一個可變長度的參數

輸出為:

在上例中, strs ...string 中, strs 的實際值是b,c,d,e,這就是一個最簡單的傳遞可變長度的參數的例子,更多一些演變的形式,都非常類似

在GO中 defer 關鍵字非常重要,相當于面相對像中的析構函數,也就是在某個函數執(zhí)行完成后,GO會自動這個;

如果在多層循環(huán)中函數里,都定義了 defer ,那么它的執(zhí)行順序是先進后出;

當某個函數出現嚴重錯誤時, defer 也會被調用

輸出為

這是一個最簡單的測試了,當然還有更復雜的調用,比如調試程序時,判斷是哪個函數出了問題,完全可以根據 defer 打印出來的內容來進行判斷,非??焖?,這種留給你們去實現

一個函數在函數體內自己調用自己我們稱之為遞歸函數,在做遞歸調用時,經常會將內存給占滿,這是非常要注意的,常用的比如,快速排序就是用的遞歸調用

本篇重點介紹了GO函數(func)的聲明與使用,下一篇將介紹GO的結構 struct

golang 怎么返回多條記錄

goalng函數多返回值

func?returnMuti()?(a?int,b?int){

return?93,?97???

}

網站名稱:go語言多返回值 golang返回多個值
本文網址:http://muchs.cn/article34/hgsjse.html

成都網站建設公司_創(chuàng)新互聯,為您提供動態(tài)網站、關鍵詞優(yōu)化服務器托管、云服務器、網站設計公司、網站制作

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯

外貿網站建設