- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我是 Go 的新手,所以如果我的问题的答案很明显,我提前道歉 :)
我正在计划一个读取文件并将每一行发送到 channel 的制作人,例如:
scanner := bufio.NewScanner(file)
for scanner.Scan() {
processingChan <- scanner.Text()
}
并添加一些 goroutines 来消耗这些行。
现在,我想要的是,如果任何行在 goroutine 中无法处理(假设该行包含我的业务规则的无效值),我想停止生产者循环,关闭文件(已延迟)并完成程序。
问题是:如何“通知”生产者循环/for 停止?
我发现有人建议:
for scanner.Scan() {
select {
case <- quit:
// break / return
default:
// send next line to channel
}
}
并且消费者 goroutine 会在出现任何故障时写入“退出”(或错误) channel 。
这种方法可能会解决问题,但我想知道是否有更清洁/更好或只是常见/流行的方法。
最佳答案
正确,使用退出 channel 。特别是当您已经在循环中发送到 channel 时,处理额外的 channel 很容易。但是,我不会使用您建议的形式,而是使用更简单和更安全 的版本:
for scanner.Scan() {
select {
case <- quit:
return
case processingChan <- scanner.Text():
}
}
为什么更安全?因为它不会死锁,这与您使用 default
的示例相反。您可能很幸运,从未遇到过它,但在某些情况下您会遇到。问题在于你有两个例程相互交谈,这总是需要更多的关注。考虑一下:
quit := make(chan error, 1)
prod := make(chan int)
go func() {
for n := range prod {
runtime.Gosched()
if n%66 == 0 {
quit <- errors.New("2/3 of evil")
return
}
}
}()
for n := 1; n < 1000; n++ {
select {
case <-quit:
fmt.Println(n)
return
default:
prod <- n
}
}
//https://play.golang.org/p/3kDRAAwaKR
轰!主程序试图发送到 prod
channel ,但是没有人接收它;我们的消费者也有同样的问题。
向 channel 添加缓冲区也不会解决问题,但会降低它的可能性。
将前面的示例与以下更改进行比较:
select {
case <-quit:
fmt.Println(n)
return
case prod <- n:
}
//https://play.golang.org/p/pz8DMYdrVV
效果很好。
我知道有人想使用第一个选项来确保他们尽早退出,但如果您在退出前发送一两个额外的项目进行处理,这通常不是什么大问题。
关于golang 惯用的方式来停止 for,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33400530/
我对 Clojure 和函数式编程有了大约一周的了解——我的所有背景都是 OOP。我想利用 Clojure 备受争议的易读性和固有逻辑,但现在我不知道我是否成功地做到了这一点,只是没有完全理解它,或者
场景: val col: IndexedSeq[Array[Char]] = for (i = 0 && arr(last.y)(west) == '.') { arr(last.y)(w
我正面临 AngularJS、服务和范围的“问题”。 这不是一个真正的问题(我找到了几种使其工作的方法),但我想知道我是否在做正确的事情,或者我正在做的事情是否会导致将来出现问题 我有一个保存一些全局
进行以下数据结构转换的“Rubyist”方法是什么: 我有 incoming = [ {:date => 20090501, :width => 2}, {:
如何在 go 中编写返回集合最小值的函数?我不只是在寻找解决方案(我知道我可以在遍历第一个元素时只初始化最小值,然后设置一个我初始化最小值的 bool 变量),而是一个惯用的解决方案。由于 go 没有
好的,我知道我应该对我的特定应用程序进行基准测试,等等,但是: -Xmx 的默认 JVM 设置、默认垃圾收集器等,对于大多数典型的 Java 程序来说是合理的默认设置,并且可能不适合惯用的 Scala
既然 shared_ptr 在 tr1 中,你认为 std::auto_ptr 的使用会发生什么?它们都有不同的用例,但 auto_ptr 的所有用例也都可以用 shared_ptr 解决。你会放弃
这个问题在这里已经有了答案: What are the differences between type() and isinstance()? (8 个回答) 关闭 9 年前。 我需要知道 Pyth
在指定和创建数字函数时,是否有关于何时返回 null 以及何时返回 NaN 的任何 C# 惯用准则,当两者似乎都是有效输出时。 导致这个问题的具体例子是我正在为 Enumerable 集合创建一个百分
这个问题在这里已经有了答案: Retrieving the top 100 numbers from one hundred million of numbers [duplicate] (12 个
我可以通过反射检索方法,以某种方式将其与目标对象结合起来,并将其作为看起来像 Scala 中的函数的东西返回(即您可以使用括号调用它)吗?参数列表是可变的。它不一定是“一流”函数(我已经更新了问题),
我是一名优秀的程序员,十分优秀!