Golang團(tuán)隊(duì)認(rèn)為在類(lèi)型系統(tǒng)和運(yùn)行時(shí)的復(fù)雜性花費(fèi)太大,還沒(méi)找到可以和這個(gè)復(fù)雜性相抵的良好設(shè)計(jì)。
成都創(chuàng)新互聯(lián)專(zhuān)注于企業(yè)成都營(yíng)銷(xiāo)網(wǎng)站建設(shè)、網(wǎng)站重做改版、尼開(kāi)遠(yuǎn)網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、成都h5網(wǎng)站建設(shè)、商城建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)公司、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性?xún)r(jià)比高,為尼開(kāi)遠(yuǎn)等各大城市提供網(wǎng)站開(kāi)發(fā)制作服務(wù)。
內(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類(lèi)型數(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è)支持任意類(lèi)型的接口,任何其他類(lèi)型的數(shù)據(jù)只要實(shí)現(xiàn)了這個(gè)接口,就可以用這個(gè)接口中的函數(shù)來(lái)排序了。
以上就是golang不支持泛型嗎?的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注創(chuàng)新互聯(lián)其它相關(guān)文章!
文章題目:go語(yǔ)言支持泛型嗎
網(wǎng)站地址:http://www.rwnh.cn/article34/jeedse.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)、外貿(mào)建站、標(biāo)簽優(yōu)化、Google、網(wǎng)站排名、搜索引擎優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)