Golang團(tuán)隊(duì)認(rèn)為在類型系統(tǒng)和運(yùn)行時(shí)的復(fù)雜性花費(fèi)太大,還沒(méi)找到可以和這個(gè)復(fù)雜性相抵的良好設(shè)計(jì)。
成都創(chuàng)新互聯(lián)公司成立于2013年,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元下陸做網(wǎng)站,已為上家服務(wù),為下陸各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:18982081108內(nèi)置的map和slice其實(shí)都有泛型的味道,加上可以用interface{}來(lái)構(gòu)造容器,可以達(dá)到泛型的效果。所以目前為止還沒(méi)有直接的支持泛型。
我們這里打算以一些例子來(lái)講解Golang中如何處理這個(gè)問(wèn)題。
首先,我們看一個(gè)冒泡排序的問(wèn)題。針對(duì)整型數(shù)組切片的排序。
package main import ( "fmt" ) func bubbleSort(array []int) { for i := 0; i < len(array); i++ { for j := 0; j < len(array)-i-1; j++ { if array[j] > array[j+1] { array[j], array[j+1] = array[j+1], array[j] } } } } func main() { a1 := []int{3, 2, 6, 10, 7, 4, 6, 5} bubbleSort(a1) fmt.Println(a1) }
上面的例子輸出為:
[2 3 4 5 6 6 7 10]
那么,我們?nèi)绻M@個(gè)bubbleSort能夠同時(shí)支持float類型數(shù)據(jù)排序,或者是按照字符串的長(zhǎng)度來(lái)排序應(yīng)該怎么做呢?
在其他的例如java語(yǔ)言中,我們可以將bubbleSort定義為支持泛型的排序,但是Go里面就不行了。為了達(dá)到這個(gè)目的,我們可以使用interface來(lái)實(shí)現(xiàn)相同的功能。
針對(duì)上面的排序問(wèn)題,我們可以分析一下排序的步驟:
查看切片長(zhǎng)度,以用來(lái)遍歷元素(Len);
比較切片中的兩個(gè)元素(Less);
根據(jù)比較的結(jié)果決定是否交換元素位置(Swap)。
到這里,或許你已經(jīng)明白了,我們可以把上面的函數(shù)分解為一個(gè)支持任意類型的接口,任何其他類型的數(shù)據(jù)只要實(shí)現(xiàn)了這個(gè)接口,就可以用這個(gè)接口中的函數(shù)來(lái)排序了。
以上就是golang不支持泛型嗎?的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注創(chuàng)新互聯(lián)其它相關(guān)文章!