php小編蘋果為大家?guī)?lái)了關(guān)于Go 1.20版本中如何計(jì)算連接錯(cuò)誤的介紹。在新版本中,Go語(yǔ)言提供了一種更精確的連接錯(cuò)誤計(jì)算方法,可以更好地監(jiān)控和處理網(wǎng)絡(luò)連接的異常情況。通過(guò)對(duì)連接錯(cuò)誤的準(zhǔn)確計(jì)算,開(kāi)發(fā)者能夠更快地定位和解決網(wǎng)絡(luò)連接的問(wèn)題,提高程序的穩(wěn)定性和性能。本文將詳細(xì)介紹Go 1.20版本中連接錯(cuò)誤計(jì)算的原理和使用方法,幫助開(kāi)發(fā)者更好地應(yīng)對(duì)網(wǎng)絡(luò)連接異常。
問(wèn)題內(nèi)容
據(jù)我了解, errors.Join()
是多錯(cuò)誤集合類型的開(kāi)箱即用替代品,例如 hashcorp/multierror ,它收集并行發(fā)生的錯(cuò)誤。這個(gè)問(wèn)題不解決常規(guī)錯(cuò)誤包裝/展開(kāi)。
當(dāng)我替換生產(chǎn)代碼時(shí),一些測(cè)試在嘗試計(jì)算連接錯(cuò)誤時(shí)失敗。錯(cuò)誤的數(shù)量和類型對(duì)于管理業(yè)務(wù)案例都很重要。這適用于 hashcorp/multierror,因?yàn)闀?huì)生成某個(gè)字符串,例如 3 錯(cuò)誤發(fā)生
。
package main import "errors" func doSomething() error { var multierror error err1 := errors.New("Hello") multierror = errors.Join(err1, err1) err2 := errors.New("World") multierror = errors.Join(err2, err1) return multierror } // somewhere else func test_doSomething(t *testing.T) { actual := doSomething() assert.Len(t, 2, len(actual)????) // help }
登錄后復(fù)制
使用 errors.Join()
后如何統(tǒng)計(jì)錯(cuò)誤數(shù)量?
我找不到一種方法來(lái)檢查連接錯(cuò)誤內(nèi)的錯(cuò)誤切片的性質(zhì),并且檢查所述錯(cuò)誤切片本身是不可能的,因?yàn)樗撬接械摹?/p>
使用 errors.Unwrap(err)
可能是一種方法,盡管我得到的只是一個(gè)錯(cuò)誤或 nil
(如果它是最后一個(gè))。除了 errors.As/.Is
之外,它并不完全讓我們解決計(jì)數(shù)錯(cuò)誤。
解決方法
errors.Join()
記錄:
因此 errors.Join()
返回的 error
將有一個(gè) Unwrap() []error
方法。 類型斷言 持有該方法的接口類型,您可以調(diào)用它,它將返回連接的切片錯(cuò)誤:
例如:
err1 := errors.New("err1") err2 := errors.New("err2") err := errors.Join(err1, err2) if uw, ok := err.(interface{ Unwrap() []error }); ok { errs := uw.Unwrap() fmt.Println("Number of joined errors:", len(errs)) }
登錄后復(fù)制
這將輸出(在 Go Playground 上嘗試):
Number of joined errors: 2
登錄后復(fù)制