這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
Java當中有instanceof這樣的關鍵字判斷類型 Go當中自然也有相應的方法來判斷類型
即Comma-ok斷言
寫法為value, ok := em.(T) 如果確保em 是同類型的時候可以直接使用value:=em.(T)一般用於switch語句中下面將會講解到
em代表要判斷的變數
T代表被判斷的類型
value代表返回的值
ok代表是否為改類型
類型斷言應該一看就懂 在這裡就不再介紹了主要是介紹我自己碰到的幾個問題
1 em必須為initerface類型才可以進行類型斷言
比如如下代碼會報錯
s := "BrainWu"if v, ok := s.(string); ok {fmt.Println(v)}
invalid type assertion: s.(string) (non-interface type string on left)
在這裡只要是在聲明時或函數傳進來的參數不是interface類型那麼做類型斷言都是回報 non-interface的錯誤的
所以我們只能通過將s作為一個interface{}的方法來進行類型斷言 如下代碼所示
s := "BrainWu"if v, ok := interface{}(s).(string); ok {fmt.Println(v)}
將s顯示的轉換為interface{}介面類型則可以進行類型斷言了
2 當函數作為參數並且被調用函數將參數類型指定為interface{}的時候是沒有辦法直接調用該方法的
比如如下代碼是錯誤的在編譯期間就會報錯
cannot convert in (type interface {}) to type Handler: need type assertion
func ServeHTTP(s string) {fmt.Println(s)}type Handler func(string)func panduan(in interface{}) {Handler(in)("wujunbin")}func main() {panduan(Handler(ServeHTTP))}
根據錯誤提示是說要我們先進行類型斷言才可以繼續使用該類型的函數
if v, ok := in.(Handler); ok {//跟什麼類型判斷就只能調用什麼類型的方法v("BrainWu")}
只有讓傳進來的in參數先與Handler進行類型判斷 如果傳回值是OK則代表類型相同才能進行對應的方法調用
另外進行類型斷言之後如果斷言成功 就只能使用該類型的方法比如對一個結構體S進行與A介面斷言
S實際上實現了A B兩個介面
A interface 具有 a()方法 B interface 具有 b()方法 如果結構體S作為參數被傳入一個函數中並且在該函數中是interface{}類型
那麼進行與A的類型斷言之後就只能調用a()而不能調用b()因為編譯器只知道你目前是A類型卻不知道你目前也是B類型
3 另外講解 switch與類型斷言的結合使用還是比較方便的
比如下面這個例子
package mainimport ("fmt")type Element interface {}func main() {var e Element = 100switch value := e.(type) {case int:fmt.Println("int", value)case string:fmt.Println("string", value)default:fmt.Println("unknown", value)}}
type是一個關鍵字
著作權聲明:本文為博主原創文章,未經博主允許不得轉載。