Go 如何返回延迟错误
看看下面的函数Go 如何返回延迟错误,go,deferred,Go,Deferred,看看下面的函数 // JsonGet makes an HTTP Get call func JsonGet(url string) ([]byte, int, error) { timeout := time.Duration(timeoutInSecs * time.Second) client := http.Client{ Timeout: timeout, } request, err := http.NewRequest("
// JsonGet makes an HTTP Get call
func JsonGet(url string) ([]byte, int, error) {
timeout := time.Duration(timeoutInSecs * time.Second)
client := http.Client{
Timeout: timeout,
}
request, err := http.NewRequest("GET", url, nil)
request.Header.Set("Content-type", "application/json")
if err != nil {
return nil, 0, err
}
resp, err := client.Do(request)
if err != nil {
return nil, 0, err
}
// At this point we know we are successful so we can defer the close
// https://blog.learngoprogramming.com/5-gotchas-of-defer-in-go-golang-part-iii-36a1ab3d6ef1
defer func(f io.Closer) {
if err := f.Close(); err != nil {
log.Println("Error Deferring resp.Body.Close (io.Closer)")
}
}(resp.Body)
body, err := ioutil.ReadAll(resp.Body)
if err != nil {
return nil, 0, err
}
return body, resp.StatusCode, nil
}
我对延迟功能有疑问
error
作为命名值返回,则可以更改error
中的参数值defer
您将如何更改此功能以适应此情况
您可以从博客页面中查找此示例。在如下命名返回参数的情况下,deferred函数修改i
的值
func()(i int){
defer func(){i++}()
返回1
}
并将其与如下未命名参数返回的情况进行比较,在这种情况下,延迟函数中的操作不会反映在r
func()(int){
r:=1
defer func(){r++}()
返回r
}
如果成功,是否在返回后关闭
如果您的函数能够成功地处理响应,即在语句返回body,resp.StatusCode,nil
之后,或者当它无法读取返回nil,0,err
时,延迟函数将在这两种情况下执行
是否曾经出现过这样的情况:此函数可能返回结果,然后尝试执行延迟和错误,但已返回
不确定您在这里引用的用例是什么,但是当周围的函数返回时,延迟函数是最后的执行点。因此,当您有一个延迟函数时,不可能出现已经返回的情况。延迟函数调用中的错误是正常的,例如,在您的代码中,关闭读卡器时可能会出错,在这种情况下,您所能做的就是修改命名的返回参数以指示错误的性质。afaik resp.Body.Close返回错误的可能性为零。但是,根据延迟的实现情况,可能会隐藏错误。。。“好吧,resp.Body.Close的可能性为零”——仅使用stdlib时可能是这样,但由于http.RoundTripper
可以用任何实现的io.ReadCloser
替换Body,因此无法在所有情况下保证这一点。