新入GO门,请教大神们关于defer的一个问题

zoupeng77 · 2018-01-23 17:50:44 · 1089 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2018-01-23 17:50:44 的主题,其中的信息可能已经有所发展或是发生改变。

func abc() interface{} {
    blogRows, _ := models.Db.Query("select * from blog where id=1")
    defer blogRows.Close()
    catRows, _ := models.Db.Query("select * from category where id=1")
    defer catRows.Close()
    return 1
}

这样并没有实现我想要的释放掉两个资源,似乎只释放了一个。于是我又做了以下实验:

func abc() interface{} {
    blogRows, _ := models.Db.Query("select * from blog where id=1")
    blogRows.Close()
    catRows, _ := models.Db.Query("select * from category where id=1")
    defer catRows.Close()
    return 1
}

这样就都能释放

func abc() interface{} {
    blogRows, _ := models.Db.Query("select * from blog where id=1")
    defer blogRows.Close()
    catRows, _ := models.Db.Query("select * from category where id=1")
    catRows.Close()
    return 1
}

这样同样只释放了一个

func abc() interface{} {
    blogRows, _ := models.Db.Query("select * from blog where id=1")
    blogRows.Close()
    catRows, _ := models.Db.Query("select * from category where id=1")
    catRows.Close()
    return 1
}

这样当然肯定是没有问题的,都能释放

请教各位大神,这个defer在这里面究竟是个什么原理。


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1089 次点击  
加入收藏 微博
4 回复  |  直到 2018-01-24 16:04:10
zoupeng77
zoupeng77 · #1 · 7年之前

好了,自己解决了。我发现第一个查询在没有关闭的情况下,创建新的查询,不管后面怎么关闭,都关闭不了第一个查询。

lishihai
lishihai · #2 · 7年之前

具体如何解决的,能分享下么?

为什么"第一个查询在没有关闭的情况下,创建新的查询,不管后面怎么关闭,都关闭不了第一个查询"?

你用的什么包来做数据库操作的?

JJJJJJJerk
JJJJJJJerk · #3 · 7年之前
lishihailishihai #2 回复

具体如何解决的,能分享下么? 为什么"第一个查询在没有关闭的情况下,创建新的查询,不管后面怎么关闭,都关闭不了第一个查询"? 你用的什么包来做数据库操作的?

我猜使用的是gorm

zoupeng77
zoupeng77 · #4 · 7年之前
lishihailishihai #2 回复

具体如何解决的,能分享下么? 为什么"第一个查询在没有关闭的情况下,创建新的查询,不管后面怎么关闭,都关闭不了第一个查询"? 你用的什么包来做数据库操作的?

mysql数据库包:github.com/go-sql-driver/mysql,只不过我把*sql.DB对象放在项目的models包里。 我具体分析下: 例1和例3中,blogRows都是用defer延迟关闭的,所以在catRows创建查询的时候,blogRows是没有关闭的,catRows创建后,无论catRows是否关闭,blogRows都会被一直挂起,无法关闭,我设计出第5例:

func abc() interface{} {
    blogRows, _ := models.Db.Query("select * from blog where id=1")
    catRows, _ := models.Db.Query("select * from category where id=1")
    catRows.Close()
    blogRows.Close()
    return 1
}

这样,blogRows依然关闭不了。 我也就发现了这个问题,但究竟是怎么造成的,还不知道。现在的解决方式是,查询一次导出数据后立即关闭,不能在查询中套查询,不能在查询中用递归函数。

添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传