ZhangZhihui's Blog  

Then looking at this code:

res, err := client.Do(req)
defer res.Body.Close()

if err != nil {
    return nil, err
}

I'm guessing that err is not nil. You're accessing the .Close() method on res.Body before you check for the err.

The defer only defers the function call. The field and method are accessed immediately.


So instead, try checking the error immediately.

res, err := client.Do(req)

if err != nil {
    return nil, err
}
defer res.Body.Close()

 

复制代码
CONNECT_DB:
    _, err = connPool.Query(ctx, "SELECT * FROM users LIMIT 1;")
    fmt.Println(err)
    if strings.Contains(err.Error(), "failed to connect to") {
        if retryTimes < RETRY_LIMIT {
            retryTimes++
            time.Sleep(RETRY_INTERVAL)
            goto CONNECT_DB
        } else {
            log.Fatal("failed to connect to db:", err)
        }
    }
复制代码

 

复制代码
zzh@ZZHPC:/zdata/Github/zimplebank$ go run main.go
<nil>
panic: runtime error: invalid memory address or nil pointer dereference
[signal SIGSEGV: segmentation violation code=0x1 addr=0x18 pc=0x9772d3]

goroutine 1 [running]:
main.init.0()
        /zdata/Github/zimplebank/main.go:42 +0x353
exit status 2
复制代码

Cause: err is nil, but uses err.Error().

Adding nil check can fix this error.

posted on   ZhangZhihuiAAA  阅读(27)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
 
点击右上角即可分享
微信分享提示