## singleflight.Do 方法中的 shared 值为何始终为 true?

## singleflight.do 方法中的 shared 值为何始终为 true?

go 并发库 singleflight 中 shared 值为何始终为 true

在 singleflight.do 方法中,第三个参数 shared 是一个布尔值,指示是否共享结果。按照注释的描述,该值应指示 v 值是否被多个调用者共享。但是,用户遇到了一个问题,无论调用次数多少,shared 值始终返回 true。

为了探究这个问题,我们分析了代码:

package main

import (
    "fmt"
    "sync"
    "time"

    "golang.org/x/sync/singleflight"
)

func main() {
    g := singleflight.group{}
    wg := sync.waitgroup{}

    for i := 0; i <p>从代码中可以看出,使用 singleflight.group 执行并发查询,向 <a style="color:#f60; text-decoration:underline;" href="https://www.php.cn/zt/15713.html" target="_blank">mysql</a> 查询用户 id。</p><p>根据 singleflight.do 方法的文档,第四个返回参数 shared 的含义是:</p>
the return value shared indicates whether v was given to multiple callers.

这意味着 shared 参数指示 v 值是否被多个调用者共享。因此,对同一查询的多个并发调用应该得到相同的 v 值,并且 shared 应该为 true。

但是,在给定的示例中,无论调用次数,shared 始终为 true。这是因为单一飞行模型的设计使然。在单一飞行模型中,并发请求被合并为一个请求,并且只有第一个请求执行查询。因此,所有并发请求都将收到相同的 v 值,从而导致 shared 始终为 true。

以下代码段说明了这一点:

group.Do("query", func() (interface{}, error) {
    // 查询数据库
    return queryDB()
})

在这个代码块中,singleflight.do 方法将确保只有一个并发调用执行 querydb 函数,其余并发调用将收到相同的结果。因此,所有并发调用将共享相同的 v 值,导致 shared 始终为 true。

因此,给定示例中的 shared 始终为 true 的行为是符合预期的,并且是由 singleflight.do 方法的设计造成的。

以上就是## singleflight.Do 方法中的 shared 值为何始终为 true?的详细内容,更多请关注其它相关文章!