一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Golang - Go語言 channel如何實現歸并排序中的merge函數詳解

Go語言 channel如何實現歸并排序中的merge函數詳解

2020-05-13 11:22hezhiming Golang

這篇文章主要給大家介紹了關于Go語言 channel如何實現歸并排序中merge函數的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。

前言

初識go語言不到半年,我是一次偶然的機會認識了golang這門語言,看到他簡潔的語法風格和強大的語言特性,瞬間有了學習他的興趣

最近學習 Go,但是苦于沒有項目練手,于是便逼迫自己:如果想到什么有趣的東西,看能不能用 Go 實現一遍,于是便有了這篇流水文。

實現過程

歸并排序中的 merge 函數,相信每個人都很熟悉,網上隨便搜搜都有一大堆文章,這里不再贅述細節。一開始,我用的是常規套路,不過覺得沒啥意思,無非是「換湯不換藥,感覺還是在拿自己熟悉的語言寫東西」。

聯想到 Go 的 channel 似乎能在某種程度上滿足我的要求,再加上 Goroutine 這種東西,便想:是不是也能利用利用這兩個語言特性。

channel 這個數據結構,在 Go 中有比較豐富的含義,但我基本上把它當隊列使用。Goroutine 也一樣,我基本把它等同于「用戶態線程」(兩者都很牛逼,不過作為應用層的開發者,有時候并不想深究太多,一切都往簡單方向理解)。

由于我只是練手,所以我想到的 API 長這樣:

?
1
Merge(ch1, ch2): outChan

給定兩個有序的 channel,然后將其合并為一個有序的 channel。

于是我的實現如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
func Merge(ch1 <-chan int, ch2 <-chan int) <-chan int {
  out := make(chan int)
  go func() {
    // 等上游的數據 (這里有阻塞,和常規的阻塞隊列并無不同)
    v1, ok1 := <-ch1
    v2, ok2 := <-ch2
    // 取數據
    for ok1 || ok2 {
      if !ok2 || (ok1 && v1 <= v2) {
        // 取到最小值, 就推到 out 中
        out <- v1
        v1, ok1 = <-ch1
      } else {
        out <- v2
        v2, ok2 = <-ch2
      }
    }
    // 顯式關閉
    close(out)
  }()
  // 開完goroutine后, 主線程繼續執行, 不會阻塞
  return out
}

使用 Go 的感受

語法近乎簡陋。不過對我而言并無大礙,反而喜歡。不太喜歡語法特性(語法糖)太多的語言,亂糟糟的,分散了太多注意力。要是每個語法特性都是相互正交的,我自然雙手贊同,但是如果多個特性都在做同一件事情,一般對學習者的負擔比較大的(Ruby),也不利于合作。

編譯型。不多講,幾乎已經是俺學習新語言的必要條件了,前期開發效率可能會慢點,但是換來的是更少的 bug,尤其是對團隊協作,可以減少很多痛苦。(要是你團隊里面都是高手,用 Python 自然是爽歪歪,但是這一條件并不總是滿足。所以還是使用能編譯的語言吧 :))

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。

原文鏈接:https://juejin.im/post/5a6f3dbe6fb9a01c9332f26f

延伸 · 閱讀

精彩推薦
  • GolangGolang中Bit數組的實現方式

    Golang中Bit數組的實現方式

    這篇文章主要介紹了Golang中Bit數組的實現方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    天易獨尊11682021-06-09
  • Golanggolang json.Marshal 特殊html字符被轉義的解決方法

    golang json.Marshal 特殊html字符被轉義的解決方法

    今天小編就為大家分享一篇golang json.Marshal 特殊html字符被轉義的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧 ...

    李浩的life12792020-05-27
  • Golanggolang的httpserver優雅重啟方法詳解

    golang的httpserver優雅重啟方法詳解

    這篇文章主要給大家介紹了關于golang的httpserver優雅重啟的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,...

    helight2992020-05-14
  • Golanggolang 通過ssh代理連接mysql的操作

    golang 通過ssh代理連接mysql的操作

    這篇文章主要介紹了golang 通過ssh代理連接mysql的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    a165861639710342021-03-08
  • Golanggolang如何使用struct的tag屬性的詳細介紹

    golang如何使用struct的tag屬性的詳細介紹

    這篇文章主要介紹了golang如何使用struct的tag屬性的詳細介紹,從例子說起,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看...

    Go語言中文網11352020-05-21
  • Golanggo語言制作端口掃描器

    go語言制作端口掃描器

    本文給大家分享的是使用go語言編寫的TCP端口掃描器,可以選擇IP范圍,掃描的端口,以及多線程,有需要的小伙伴可以參考下。 ...

    腳本之家3642020-04-25
  • Golanggo日志系統logrus顯示文件和行號的操作

    go日志系統logrus顯示文件和行號的操作

    這篇文章主要介紹了go日志系統logrus顯示文件和行號的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    SmallQinYan12302021-02-02
  • GolangGolang通脈之數據類型詳情

    Golang通脈之數據類型詳情

    這篇文章主要介紹了Golang通脈之數據類型,在編程語言中標識符就是定義的具有某種意義的詞,比如變量名、常量名、函數名等等,Go語言中標識符允許由...

    4272021-11-24
主站蜘蛛池模板: 五月婷婷丁香在线视频 | 99美国热| 学校捏奶揉下面污文h | 国产成人99精品免费观看 | 日韩国产成人资源精品视频 | 成人欧美一区在线视频在线观看 | 男女激情视频1000辣妞范 | 性印度freehd | b站免费 | 视频在线播放 | 成人午夜剧场 | 日韩精品成人免费观看 | 成人精品一级毛片 | 不知火舞被c视频在线播放 不卡一区二区三区卡 | 日韩在线天堂免费观看 | 美女黄a | 成人免费公开视频 | 91国内精品久久久久影院优播 | 国产成人99精品免费观看 | 亚洲 综合 欧美在线视频 | 国产精品久久久久a影院 | 日韩在线观看一区二区不卡视频 | 4hc44四虎永久地址链接 | 干处女| 性色老女人 | 福利视频一区二区三区 | asian4you裸模| 99ri在线视频网 | 国产乱码一卡二卡3卡四卡 国产乱插 | 赤色疑惑| 五月最新商场女厕所高跟嘘嘘 | boobsmilking流奶水野战 | 美女脱了内裤打开腿让人桶网站o | 国产91在线精品 | 欧美视频一二三区 | 欧美国产在线观看 | 九九99亚洲精品久久久久 | 干b视频在线观看 | 国产成人久久 | 免费av在线视频 | 女人爽到喷水的视频免费看 |