這是它的優點,因為編譯器在編譯時不去確定你傳的到底是什么類型,你傳一個string,它能接收,你傳一個對象struct,它也能接收,它只有一個要求,實現我要求實現的方法!
創新互聯公司主要從事成都網站設計、做網站、成都外貿網站建設公司、網頁設計、企業做網站、公司建網站等業務。立足成都服務六安,10多年網站建設經驗,價格優惠、服務專業,歡迎來電咨詢建站服務:18982081108
既然interface是不限定類型,是通用類型,這是一種開放表現,這種開放怎么實現的呢?方差敬法就是不去檢驗你的類型,既然不檢驗那也不去記錄你的類型?。。。∽⒁鈏nterface不記錄你的類型,所以不管你是string,struct,int,我都不管,我都不記錄,我只記錄你的地址,結果是編譯器在編譯時也不知道你是什么類型,你有什么字段!
但是現在有一個問題,編譯器也沒辦法確定一個interface以前是什么類型?。ň幾g時)這就是因果關系:為了達到通用,interface不做確定工作,結果就是interface也不知道以前的類型。
一個類型轉接口的過程,就是放棄自我類型的過程,變成了沒有類型。
這樣做有什么好處呢,很顯然是:通用,如果把一個函數的傳入參數設置為空接口(interface{}),那么任何類型當做參數都能夠調用該接口,最好的例子就是:
它就是一個很標準的例子,println傳入參數可以是任何類型,都能打印出它的值。
當然你可以說你記得,因為是你把它轉換成interface,你理所當然的記得,可編譯器不知道啊,interface不包含類型,也就是說你沒有讓它去記錄,所以它不知道。
針對這個問題,go語言給了一個解決方案,斷言,當將一個interface轉換成它原來類型的時候,在它后面指明它的原來類型,這樣編譯器就知道該按照什么類型去解析了。(其實說白了,這就是通過人的記憶,編譯器不知道是什么類型,你告訴編譯器就可以了)
斷言其實是先獲取interface的動態類型,然后與你指定的類型做判斷,如果一致,將它轉換成你指定的類型。如果不知道動態類型,可以看這篇文章:
從報錯可以看出, 不能直接轉換,需要對接口先進行斷言
通常情況下,一個變量在確定類型的情況下編譯器知道他有哪些功能(注意,這里是針對編譯時),比如一個int類型,編譯器在編譯時知道能對他加減int,不能加減float,如果你這么做我就給你報錯。一個struct包含哪些字段,不包含哪些字段,我定義一個user結構體,里面只有name和age兩個字段,那么你只能取我這兩字段的值,你如果取height,我就給你報錯。
這些都是正常情況下的,但是對于一個接口呢,編譯器會變成瞎子!在編譯的時候它不知道你原來是什么類型,所以它也沒法確定你包含什么字段,同樣是之前那個user結構體,當把它轉換成接口以后,編譯器就對它的類型一無所知了,你獲取name字段,這有接口有沒有呢?編譯器不知道!你請求height字段,這個泛型有沒有呢?編譯器仍然不知道。所以你編譯時不能修改接口里的數據,既然編譯時 不能修改,那就只能在運行時修改了。
這個時候就該反射登場了,它能夠在運行時修改接口的數據,通過追根溯源,獲取接口底層的實際數據和類型,讓你能夠對接口的源數據進行操作。
換一種大白話的說法,反射就是刨根凳慶友問底,獲取這個接口究竟是怎么產生的,因為哪怕一個類型轉變成接口時放棄了自己的棗槐類型,但是它的本質不會變的,就像趙本山的小品里所說:小樣,別以為你脫掉馬甲我就不認識你了!對,它的底層里仍然存儲了它的數據類型,只是藏的比較深,一般手段拿不到,但我們仍然能夠通過反射(這個包根問底的工具)來確定你究竟包含哪些字段和值,確定你究竟是蛇還是脫了馬甲的烏龜!
所謂Go語言式的接口,就是不用顯示聲明類型T實現了接口I,只要類型T的公開方法完全滿足接口I的要求,就可以把類型T的對象用在需要接口I的地方。這種做法的學名叫做Structural Typing,有人也把它看作是一種靜態的Duck Typing。除了Go的接口以外,類似的東西也有比如Scala里的Traits等等。有人覺得這個特性很好,但我個人并不喜歡這種做法,所以在這里談談它的缺點。當然這跟動態語言靜態語言的討論類似,不能簡單粗暴的下一個“好”或“不好”察轎的結論。
我的觀點:
Go的隱式接口Duck Typing確實不是新技術, 但是在主流靜態編程語言中支持Duck Typing應該是很少的(不清楚目前是否只有Go語言支持).
靜態類型和動態類型雖然沒有絕對的好和不好, 但是每個都是有自己的優勢的, 沒有哪一個可以包辦一切. 而Go是試圖結合靜態類型和動態類型(interface)各自睜沒虛的優勢.
那么就從頭談起:什么是接口。其實通俗的講,接口就是一個協議,規定悉燃了一組成員,例如.NET里的ICollection接口:
public interface ICollection {
int Count { get; }
object SyncRoot { get; }
bool IsSynchronized { get; }
void CopyTo(Array array, int index);
}
這就是一個協議的全部了嗎?事實并非如此,其實接口還規定了每個行為的“特征”。打個比方,這個接口的Count除了需要返回集合內元素的數目以外,還隱含了它需要在O(1)時間內返回這個要求。這樣一個使用了ICollection接口的方法才能放心地使用Count屬性來獲取集合大小,才能在知道這些特征的情況下選用正確的算法來編寫程序,而不用擔心帶來性能問題,這才能實現所謂的“面向接口編程”。當然這種“特征”并不但指“性能”上的,例如Count還包含了例如“不修改集合內容”這種看似十分自然的隱藏要求,這都是ICollection協議的一部分。
在正常的測試中,當我們需要進閉橘行接口測試時,通常使用接口調試工具,如postman進行接口測試
目前我在嘗試使用Go語言進行接口測試,使用的庫均為Go自帶的庫。
注:當前采用的接碧瞎口為時事新聞接口,每天可以請求100次,需要的同轎慧團學,可以自行使用。
本文標題:go語言中編寫接口 golang寫接口
本文地址:http://m.newbst.com/article28/ddpopcp.html
成都網站建設公司_創新互聯,為您提供網站收錄、網站導航、網站建設、營銷型網站建設、ChatGPT、網站策劃
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯