第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機(jī)立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在 Go 中使用反射檢查兼容類型

在 Go 中使用反射檢查兼容類型

Go
慕妹3146593 2021-08-23 15:49:08
雖然我知道在 Go 中恐慌可能不是慣用的,但我想測試以確保函數(shù)在某些條件下而不是在其他條件下發(fā)生恐慌。函數(shù)的一個例子。func PanicOnErr(potentialErr error) {    if potentialErr != nil {        panic(potentialErr)    }}以下是檢查函數(shù)是否會 panic 的實(shí)現(xiàn)。func InvocationCausedPanic(f interface{}, params ...interface{}) bool {    // Obtain the function's signature.    reflectedFunc := reflect.ValueOf(f)    funcType := reflect.TypeOf(f)    if funcType.NumIn() != len(params) {        panic("InvocationCausedPanic called with a function and an incorrect number of parameter(s).")    }    reflectedParams := make([]reflect.Value, len(params))    for paramIndex, paramValue := range params {        expectedType := funcType.In(paramIndex)        actualType := reflect.TypeOf(paramValue)        if actualType != expectedType {            errStr := fmt.Sprintf("InvocationCausedPanic called with a mismatched parameter type [parameter #%v: expected %v; got %v].", paramIndex, expectedType, actualType)            panic(errStr)        }        reflectedParams[paramIndex] = reflect.ValueOf(paramValue)    }    return invoke(reflectedFunc, reflectedParams)}func invoke(reflectedFunc reflect.Value, reflectedParams []reflect.Value) (panicked bool) {    defer func() {        if r := recover(); r != nil {            panicked = true        }    }()    reflectedFunc.Call(reflectedParams)    return}調(diào)用以下任一方法都會導(dǎo)致類型檢查失敗。InvocationCausedPanic(PanicOnErr, errors.New("Some error."))InvocationCausedPanic(PanicOnErr, nil)但是,似乎可以PanicOnErr使用兩者進(jìn)行調(diào)用,nil并且可以通過調(diào)用生成某些內(nèi)容errors.New(似乎是 類型*errors.errorString)。因此,有沒有辦法檢查某個參數(shù)的類型是否適合調(diào)用某個函數(shù)?雖然我知道可以使用 defer 和 recovery 來更簡單地測試函數(shù),但我很好奇是否可以編寫一個通用函數(shù)來接受任何函數(shù)和參數(shù)并確定它是否導(dǎo)致了恐慌(假設(shè)功能完成)。
查看完整描述

1 回答

?
胡子哥哥

TA貢獻(xiàn)1825條經(jīng)驗(yàn) 獲得超6個贊

使用此函數(shù)確定參數(shù)是否兼容:


func compatible(actual, expected reflect.Type) bool {

  if actual == nil {

    k := expected.Kind()

    return k == reflect.Chan || 

           k == reflect.Func || 

           k == reflect.Interface || 

           k == reflect.Map || 

           k == reflect.Ptr || 

           k == reflect.Slice

  }

  return actual.AssignableTo(expected)

}


查看完整回答
反對 回復(fù) 2021-08-23
  • 1 回答
  • 0 關(guān)注
  • 181 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號