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



}
我对延迟功能有疑问

  • 有没有一种方法可以代替记录错误来实际返回错误作为函数返回的一部分
  • 您将如何更改此功能以适应此情况
  • 对于延迟时发生的错误,应采取什么适当的状态或操作。换句话说,假设原始函数成功,因为它处理了一个请求。如果成功,是否在返回后关闭。换句话说,是否存在这样的情况,即此函数可能会返回结果,然后尝试执行延迟和错误,但已返回
  • 有没有一种方法可以代替记录错误来实际返回错误作为函数返回的一部分

    是的,如果定义的函数采用命名返回值,您可以让延迟函数修改返回值的内容(规则:第3条)。在您的情况下,如果修改函数签名以将
    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,因此无法在所有情况下保证这一点。