go語言支持泛型嗎-創(chuàng)新互聯(lián)

Golang團隊認為在類型系統(tǒng)和運行時的復(fù)雜性花費太大,還沒找到可以和這個復(fù)雜性相抵的良好設(shè)計。

成都創(chuàng)新互聯(lián)公司成立于2013年,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項目成都網(wǎng)站設(shè)計、成都網(wǎng)站制作網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元下陸做網(wǎng)站,已為上家服務(wù),為下陸各地企業(yè)和個人服務(wù),聯(lián)系電話:18982081108

內(nèi)置的map和slice其實都有泛型的味道,加上可以用interface{}來構(gòu)造容器,可以達到泛型的效果。所以目前為止還沒有直接的支持泛型。

我們這里打算以一些例子來講解Golang中如何處理這個問題。

首先,我們看一個冒泡排序的問題。針對整型數(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@個bubbleSort能夠同時支持float類型數(shù)據(jù)排序,或者是按照字符串的長度來排序應(yīng)該怎么做呢?

在其他的例如java語言中,我們可以將bubbleSort定義為支持泛型的排序,但是Go里面就不行了。為了達到這個目的,我們可以使用interface來實現(xiàn)相同的功能。

針對上面的排序問題,我們可以分析一下排序的步驟:

查看切片長度,以用來遍歷元素(Len);

比較切片中的兩個元素(Less);

根據(jù)比較的結(jié)果決定是否交換元素位置(Swap)。

到這里,或許你已經(jīng)明白了,我們可以把上面的函數(shù)分解為一個支持任意類型的接口,任何其他類型的數(shù)據(jù)只要實現(xiàn)了這個接口,就可以用這個接口中的函數(shù)來排序了。

以上就是golang不支持泛型嗎?的詳細內(nèi)容,更多請關(guān)注創(chuàng)新互聯(lián)其它相關(guān)文章!

當(dāng)前文章:go語言支持泛型嗎-創(chuàng)新互聯(lián)
URL分享:http://muchs.cn/article20/cdcpjo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、營銷型網(wǎng)站建設(shè)、響應(yīng)式網(wǎng)站、全網(wǎng)營銷推廣、企業(yè)網(wǎng)站制作微信小程序

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化