首页 >后端开发 >Golang >为什么闭包中的匿名函数只打印 For 循环中最后一个作业的描述?

为什么闭包中的匿名函数只打印 For 循环中最后一个作业的描述?

Patricia Arquette
Patricia Arquette原创
2024-11-20 18:09:13181浏览

Why Do Anonymous Functions in Closures Print Only the Last Job's Description in For Loops?

带闭包的 for 循环中的匿名函数

使用 cron 库调度任务时,迭代作业列表时会出现常见错误并尝试在循环内使用匿名函数。当每个作业应该打印自己唯一的描述,但却打印列表中最后一个作业的描述时,此错误尤其明显。

根本问题在于匿名函数处理变量的方式。迭代列表时,循环变量将按顺序获取列表中每个元素的值。但是,循环内的匿名函数绑定到原始循环变量,该变量在所有迭代之间共享。这意味着所有匿名函数最终都会使用相同的循环变量值,从而导致最后一个作业的描述被打印多次。

要解决此问题,需要为每次迭代创建一个新变量循环,从而确保每个匿名函数都有自己的变量实例。这种技术可以防止因关闭而引起的复杂情况。

for _, job := range config.Jobs {
    realJob := job // a new variable each time through the loop
    c.AddFunc("@every "+realJob.Interval, func() {
        DistributeJob(realJob)
    })
    log.Println("Job " + realJob.Name + " has been scheduled!")
}

通过此调整,每个作业都有自己的描述,并在其预定时间到达时正确打印。

以上是为什么闭包中的匿名函数只打印 For 循环中最后一个作业的描述?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn