欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Go語言 channel如何實(shí)現(xiàn)歸并排序中的merge函數(shù)詳解

 更新時(shí)間:2018年02月03日 14:00:14   作者:hezhiming  
這篇文章主要給大家介紹了關(guān)于Go語言 channel如何實(shí)現(xiàn)歸并排序中merge函數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。

前言

初識go語言不到半年,我是一次偶然的機(jī)會認(rèn)識了golang這門語言,看到他簡潔的語法風(fēng)格和強(qiáng)大的語言特性,瞬間有了學(xué)習(xí)他的興趣

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

實(shí)現(xiàn)過程

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

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

channel 這個數(shù)據(jù)結(jié)構(gòu),在 Go 中有比較豐富的含義,但我基本上把它當(dāng)隊(duì)列使用。Goroutine 也一樣,我基本把它等同于「用戶態(tài)線程」(兩者都很牛逼,不過作為應(yīng)用層的開發(fā)者,有時(shí)候并不想深究太多,一切都往簡單方向理解)。

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

Merge(ch1, ch2): outChan

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

于是我的實(shí)現(xiàn)如下:

func Merge(ch1 <-chan int, ch2 <-chan int) <-chan int {
  out := make(chan int)
  go func() {
    // 等上游的數(shù)據(jù) (這里有阻塞,和常規(guī)的阻塞隊(duì)列并無不同)
    v1, ok1 := <-ch1
    v2, ok2 := <-ch2
    // 取數(shù)據(jù)
    for ok1 || ok2 {
      if !ok2 || (ok1 && v1 <= v2) {
        // 取到最小值, 就推到 out 中
        out <- v1
        v1, ok1 = <-ch1
      } else {
        out <- v2
        v2, ok2 = <-ch2
      }
    }
    // 顯式關(guān)閉
    close(out)
  }()
  // 開完goroutine后, 主線程繼續(xù)執(zhí)行, 不會阻塞
  return out
}

使用 Go 的感受

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

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

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • go語言goto語句跳轉(zhuǎn)到指定的標(biāo)簽實(shí)現(xiàn)方法

    go語言goto語句跳轉(zhuǎn)到指定的標(biāo)簽實(shí)現(xiàn)方法

    這篇文章主要介紹了go語言goto語句跳轉(zhuǎn)到指定的標(biāo)簽實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • Go命令行參數(shù)解析flag 包使用示例詳解

    Go命令行參數(shù)解析flag 包使用示例詳解

    這篇文章主要介紹了Go命令行參數(shù)解析flag 包使用,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2024-01-01
  • Go設(shè)計(jì)模式之模板方法模式講解和代碼示例

    Go設(shè)計(jì)模式之模板方法模式講解和代碼示例

    模版方法是一種行為設(shè)計(jì)模式, 它在基類中定義了一個算法的框架, 允許子類在不修改結(jié)構(gòu)的情況下重寫算法的特定步驟,本文將通過代碼示例給大家詳細(xì)的介紹一下Go模板方法模式,需要的朋友可以參考下
    2023-08-08
  • Go web入門Go pongo2模板引擎

    Go web入門Go pongo2模板引擎

    這篇文章主要為大家介紹了Go web編程入門Go pongo2模板引擎使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • Go開源項(xiàng)目分布式唯一ID生成系統(tǒng)

    Go開源項(xiàng)目分布式唯一ID生成系統(tǒng)

    這篇文章主要為大家介紹了Go開源項(xiàng)目分布式唯一ID生成系統(tǒng)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • Golang學(xué)習(xí)筆記(一):簡介

    Golang學(xué)習(xí)筆記(一):簡介

    這篇文章主要介紹了Golang學(xué)習(xí)筆記(一):簡介,本文講解了Go語言最主要的特性、安裝、環(huán)境變量設(shè)置、整體目錄結(jié)構(gòu)、Helloworld、go命令、調(diào)試、編輯器設(shè)置等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • 使用GO語言實(shí)現(xiàn)Mysql數(shù)據(jù)庫CURD的簡單示例

    使用GO語言實(shí)現(xiàn)Mysql數(shù)據(jù)庫CURD的簡單示例

    本文主要介紹了使用GO語言實(shí)現(xiàn)Mysql數(shù)據(jù)庫CURD的簡單示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • golang 中signal包的Notify用法說明

    golang 中signal包的Notify用法說明

    這篇文章主要介紹了golang 中signal包的Notify用法說明,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • Go語言中http和mysql的實(shí)現(xiàn)代碼

    Go語言中http和mysql的實(shí)現(xiàn)代碼

    本文通過實(shí)例代碼給大家介紹了Go語言中http和mysql的實(shí)現(xiàn)代碼,非常不錯,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-11-11
  • golang使用jaeger進(jìn)行鏈路追蹤

    golang使用jaeger進(jìn)行鏈路追蹤

    鏈路追蹤是指在分布式系統(tǒng)中,將一次請求的處理過程進(jìn)行記錄并聚合展示的一種方法,目的是將一次分布式請求的調(diào)用情況集中在一處展示,本文將介紹golang如何使用jaeger進(jìn)行鏈路追蹤,需要的朋友可以參考下
    2024-06-06

最新評論