第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

如何在 Go 中獲取地圖鍵的排序列表?

如何在 Go 中獲取地圖鍵的排序列表?

Go
慕森王 2021-12-13 17:10:59
讓我們想象一下我有地圖:map[string]string。我想獲取此地圖的排序鍵列表。所以我可以做這樣的事情:func SortedMapKeys(m map[string]string) (keyList []string) {    for key := range m {        keyList = append(keyList, key)    }    sort.Strings(keyList)    return}然后我會(huì)有另一個(gè)類型的地圖map[string]bool。我也想得到它的鑰匙。但問題是函數(shù) SortedMapKeys 接受一個(gè)map[string]string參數(shù)。所以我需要編寫完全相同的函數(shù),只有一個(gè)區(qū)別 - 它會(huì)接受map[string]bool.出于顯而易見的原因,這不是一種選擇。如果有一天我想改變獲取和排序密鑰的邏輯,我將需要跟蹤和更新所有這些功能。此外,我將不得不為所有這些實(shí)際上做同樣事情的函數(shù)編寫相同的單元測(cè)試,因?yàn)樗鼈兊闹黧w是 100% 相等的(代碼重復(fù))。有沒有辦法創(chuàng)建一個(gè)可以接受map[string] 任何東西的通用函數(shù)?
查看完整描述

2 回答

?
素胚勾勒不出你

TA貢獻(xiàn)1827條經(jīng)驗(yàn) 獲得超9個(gè)贊

由于map[string]bool和map[string]string和map[string]Whatever都是不同的類型,創(chuàng)建單個(gè)函數(shù)來(lái)對(duì)所有可能map[string]*類型的鍵進(jìn)行排序的唯一方法是通過反射。


func SortedMapKeys(m interface{}) (keyList []string) {

    keys := reflect.ValueOf(m).MapKeys()


    for _, key := range keys {

        keyList = append(keyList, key.Interface().(string))

    }

    sort.Strings(keyList)

    return

}

對(duì)于中間解決方案,由于您可能只關(guān)心幾種類型的組合,您可以使用類型開關(guān)來(lái)提取鍵


func SortedMapKeys(m interface{}) (keyList []string) {

    switch m := m.(type) {

    case map[string]string:

        for k := range m {

            keyList = append(keyList, k)

        }

    case map[string]bool:

        for k := range m {

            keyList = append(keyList, k)

        }

    default:

        panic("unknown map type")

    }


    sort.Strings(keyList)

    return

}


查看完整回答
反對(duì) 回復(fù) 2021-12-13
?
湖上湖

TA貢獻(xiàn)2003條經(jīng)驗(yàn) 獲得超2個(gè)贊

這是我的 0.02 美元。由于密鑰提取邏輯不太可能改變,并且您希望將所有內(nèi)容都放在一個(gè)地方,您可以創(chuàng)建變體并從中選擇非零映射:


type MapVariant struct {

    Bool   map[string]bool

    String map[string]string

}


func SortedMapKeys(variant MapVariant) (keyList []string) {

    if variant.String != nil {

        for k := range variant.String {

            keyList = append(keyList, k)

        }

        goto SORT

    }

    if variant.Bool != nil {

        for k := range variant.Bool {

            keyList = append(keyList, k)

        }

        goto SORT

    }


SORT:

    sort.Strings(keyList)

    return

}

當(dāng)然,您可以通過添加更多條件來(lái)避免 goto 語(yǔ)句,但我個(gè)人認(rèn)為它更清晰。


然后你可以使用如下函數(shù):


SortedMapKeys(MapVariant{

    Bool: map[string]bool{"a": true, "b": false}

})

SortedMapKeys(MapVariant{

    String: map[string]string{"c": "v1", "b": "v2"}

})


查看完整回答
反對(duì) 回復(fù) 2021-12-13
  • 2 回答
  • 0 關(guān)注
  • 180 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)